Come intercettare gli errori in fase di esecuzione in un host di Script ActiveX

Il presente articolo è stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell’utente. Tuttavia, un articolo tradotto in modo automatico non è sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, più o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non è la sua. Microsoft non è responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell’utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.

Clicca qui per visualizzare la versione originale in inglese dell’articolo: 232394
Questo articolo è stato archiviato. L’articolo, quindi, viene offerto “così come è” e non verrà più aggiornato.
Nota Microsoft Visual c ++ 2005, Microsoft Visual c ++ .NET 2003 e Microsoft Visual c ++ .NET 2002 supportano sia il modello di codice gestito fornito da Microsoft .NET Framework che il modello di codice non gestito nativo di Microsoft Windows. Le informazioni contenute in questo articolo si applicano solo al codice Visual C++ non gestito.
Sommario
Come tutti i programmi, script in esecuzione in uno Script ActiveX Host può generare due tipi di errori, in fase di compilazione e fase di esecuzione. Nelle precedenti implementazioni, ActiveX Scripting Engines fornito da Microsoft, VBScript e JScript, non effettuato alcuna distinzione tra i due tipi di errori. Entrambi sono stati gestiti in IActiveScriptSite::OnScriptError() . Con le versioni più recenti dei motori di script, è stata effettuata una distinzione tra errori in fase di compilazione e di esecuzione. Errori di compilazione, ad esempio errori di sintassi, vengono ancora segnalati all'host di Script ActiveX utilizzando il metodo IActiveScriptSite::OnScriptError() . Errori di runtime, ad esempio il passaggio di argomenti non validi, tuttavia, non vengono segnalati direttamente a OnScriptError() . Al contrario, vengono segnalati a un metodo diverso, IActiveScriptSiteDebug::OnScriptErrorDebug() .

In questo articolo viene descritto come modificare un host di Script ActiveX esistenti per rilevare errori di runtime generati da script.
Informazioni
Si presume che avere già scritto un host di Script ActiveX. Per ulteriori informazioni su questa operazione, vedere gli articoli indicati nella sezione "Riferimenti" di questo articolo.

Nelle versioni più recenti dei motori di script, IActiveScriptSiteDebug::OnScriptErrorDebug chiamata quando un errore di run-time si verifica. L'interfaccia di IActiveScriptSiteDebug offre la possibilità di partecipare il debug prima il debugger è coinvolto l'host di script. Affinché l'host di script desideri essere avvisato quando un errore di run-time si verifica, è necessaria un'implementazione minima di IActiveScriptSiteDebug .

Quando viene chiamato il metodo IActiveScript::SetScriptSite , il modulo di gestione di script verrà QueryInterface IActiveScriptSite puntatore dell'host per l'interfaccia IActiveScriptSiteDebug . In questo caso, il modulo di gestione di script tenterà di contattare il debugger di script in modo autonomo. Tuttavia, se il QueryInterface ha esito positivo il modulo di gestione di script chiamerà quindi IActiveScriptSiteDebug::GetApplication() per stabilire le funzionalità di debug per la sessione di script. Se IActiveScriptSiteDebug::GetApplication() ha esito negativo, il modulo di gestione di script verrà concludere che il debug non è disponibile nel computer e ripristinare IActiveScriptSite::OnScriptError() per tutti i gestione degli errori.

Si tratta dell'interfaccia IActiveScriptSiteDebug , con un'implementazione minima:
   STDMETHOD(GetDocumentContextFromPosition)(      DWORD dwSourceContext,       ULONG uCharacterOffset,       ULONG uNumChars,       IDebugDocumentContext **ppsc) {return E_NOTIMPL;}   STDMETHOD GetApplication( IDebugApplication **ppda ) {return E_NOTIMPL;}   STDMETHOD(GetRootApplicationNode)( IDebugApplicationNode **ppdanRoot) {return E_NOTIMPL;}      STDMETHOD(OnScriptErrorDebug)(       IActiveScriptErrorDebug *pErrorDebug,       BOOL *pfEnterDebugger,      BOOL *pfCallOnScriptErrorWhenContinuing) {return E_NOTIMPL;}				
Nota In Visual c ++ 2005, in cui è necessario aggiungere l'opzione del compilatore supporto di common language runtime ( / clr: oldSyntax ) per compilare correttamente l'esempio di codice precedente. Per aggiungere il compilatore opzione supporto common language runtime, attenersi alla seguente procedura:
  1. Fare clic su progetto e quindi fare clic su proprietà ProjectName.

    Nota ProjectName è un segnaposto per il nome del progetto.
  2. Espandere la Proprietà di configurazione e quindi fare clic su Generale .
  3. Nel riquadro destro, fare clic su per selezionare supporto Common Language Runtime, vecchia sintassi (/ CLR: oldSyntax) in Common Language Runtime supporta le impostazioni del progetto.
  4. Fare clic su Applica e quindi fare clic su OK .
Per ulteriori informazioni sulle opzioni di common language runtime supporto del compilatore, visitare il seguente sito Web MSDN (informazioni in lingua inglese): In alternativa, un host di script può scegliere di un'implementazione più completa dell'interfaccia IActiveScriptSiteDebug . Per la documentazione sull'interfaccia IActiveScriptSiteDebug , visitare il sito di MSDN seguenti sito Web:
Riferimenti
Per ulteriori informazioni sulla creazione di Script ActiveX, fare clic sul numero dell'articolo della Microsoft Knowledge Base riportato di seguito riportato:
223139Come aggiungere il supporto per l'hosting VBScript per un'applicazione ATL
183698Axsh.exe viene illustrato come implementare un host di script attivo
168214MFCAxs.exe implementa un host Active Script utilizzando MFC
223389File di Scripting.exe contiene le intestazioni e il librerie necessarie creare Script ActiveX host e motori

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 232394 - Ultima revisione: 02/23/2014 11:13:34 - Revisione: 5.3

Microsoft Visual C++ 2005 Express Edition, Microsoft Visual C++ .NET 2003 Standard Edition, Microsoft Visual C++ .NET 2002 Standard Edition, Microsoft Visual C++ 6.0 Professional Edition, Microsoft Visual C++ 6.0 Enterprise Edition, Microsoft Visual C++, 32-bit Learning Edition 6.0, Microsoft Visual C++ 5.0 Professional Edition, Microsoft Visual C++ 5.0 Enterprise Edition, Visual Basic, Scripting Edition 5.0, Visual Basic, Scripting Edition 4.0, Visual Basic, Scripting Edition 3.0

  • kbnosurvey kbarchive kbmt kbactivexscript kbhowto KB232394 KbMtit
Feedback