Al momento sei offline in attesa che la connessione Internet venga ristabilita

AppInit_DLLs Registry Value e Windows 95

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: 134655
Dichiarazione di non responsabilità per articoli della Microsoft Knowledge Base su prodotti non più supportati
Questo articolo è stato scritto sui prodotti per cui Microsoft non offre più supporto. L’articolo, quindi, viene offerto ‘così come è’ e non verrà più aggiornato.
Sommario
Windows 95 non supporta il caricamento di una DLL nello spazio di un processo indirizzi mediante l'utilizzo del valore del Registro di sistema AppInit_DLLs. In Windows NT, per ogni processo eseguito, Windows carica le DLL nell'elenco il valore del Registro di sistema AppInit_DLLs nello spazio di indirizzi del processo. Per funzionalità simili in Windows 95, è possibile implementare un hook a livello di sistema. In questo articolo viene illustrato dall'esempio come eseguire questa operazione.
Informazioni
Per implementare un hook a livello di sistema, è necessario assicurarsi che la funzione di collegamento (funzione di callback) presente in una DLL. Quindi, viene chiamato quando si questa funzione, il sistema operativo associa la DLL associata nello spazio di indirizzi dell'applicazione di destinazione. L'hook della funzione quindi funziona come parte del processo dell'applicazione di destinazione.

Sono necessari essenzialmente a due passaggi coinvolti nella creazione di un hook a livello di sistema:
  1. Creare una DLL con una funzione esportata viene utilizzata come la funzione hook. Nella funzione di esempio che segue, la funzione di richiamata viene modellata dopo una funzione di callback necessarie per implementare un WH_KEYBOARD hook di sistema:
          // Trap keyboard messages      __declspec(dllexport) LRESULT CALLBACK HookFunction(                       int code,                       WPARAM wParam,                       LPARAM lParam)      {         char szVCode[50];         //display the virtual key code trapped         sprintf(szVCode, "Virtual Key code: %lx", wParam);         MessageBox(NULL, szVCode,"Key stroke", MB_OK);                :                :      }   The associated .def file for this DLL might resemble this:      LIBRARY      HOOK      EXPORTS         HookFunction						
  2. Installare l'hook di sistema. Per installare l'hook, la DLL deve essere caricata, l'hook indirizzo della funzione recuperato, e SetWindowsHookEx chiamato con l'indirizzo della funzione. Ecco un esempio:
          // add system-wide hook      hHookDll = LoadLibrary("hook");      hHookProc = (HOOKPROC) GetProcAddress(hHookDll, "HookFunction");      // Install keyboard hook to trap all keyboard messages      hSystemHook =  SetWindowsHookEx(WH_KEYBOARD,hHookProc,hHookDll,0);						
    dopo l'applicazione ha terminato con l'hook di sistema, assicurarsi di annullare il processo di associazione nel modo seguente:
          // Remove the hook and unload the DLL used for the hooking process      UnhookWindowsHookEx(hSystemHook);      FreeLibrary(hHookDll);						
4.00

Avviso: questo articolo è stato tradotto automaticamente

Proprietà

ID articolo: 134655 - Ultima revisione: 03/01/2005 15:34:49 - Revisione: 3.2

Microsoft Win32 Application Programming Interface

  • kbmt kbcode kbkernbase kbregistry KB134655 KbMtit
Feedback