2009-05-04 6 views
6

私は、成功していないメモ帳などをフックしようとしています。グローバルフックを作ることはうまくいくようです。SetWindowsHookExとWH_KEYBOARDを使用して外部プロセスをフックする方法

XP SP2でのテスト。

編集:修正されたコードは現在動作しています。

MYDLLコード

#include <windows.h> 
#include <iostream> 
#include <stdio.h> 

HINSTANCE hinst; 
#pragma data_seg(".shared") 
HHOOK hhk; 
#pragma data_seg() 
//#pragma comment(linker, "/SECTION:.shared,RWS") compiler error in VC++ 2008 express 

LRESULT CALLBACK wireKeyboardProc(int code, WPARAM wParam,LPARAM lParam) { 
    if (code < 0) { 
     return CallNextHookEx(0, code, wParam, lParam); 
    } 
    Beep(1000, 20); 
    return CallNextHookEx(hhk, code, wParam, lParam); 
} 

extern "C" __declspec(dllexport) void install(unsigned long threadID) { 
    hhk = SetWindowsHookEx(WH_KEYBOARD, wireKeyboardProc, hinst, threadID); 
} 
extern "C" __declspec(dllexport) void uninstall() { 
    UnhookWindowsHookEx(hhk); 
} 

BOOL WINAPI DllMain(__in HINSTANCE hinstDLL, __in DWORD fdwReason, __in LPVOID lpvReserved) { 
    hinst = hinstDLL; 
    return TRUE; 
} 

私のプログラム

#include <Windows.h> 

unsigned long GetTargetThreadIdFromWindow(char *className, char *windowName) 
{ 
    HWND targetWnd; 
    HANDLE hProcess; 
    unsigned long processID = 0; 

    targetWnd = FindWindow(className, windowName); 
    return GetWindowThreadProcessId(targetWnd, &processID); 
} 

int _tmain(int argc, _TCHAR* argv[]) { 
    unsigned long threadID = GetTargetProcessIdFromWindow("Notepad", "Untitled - Notepad"); 
    printf("TID: %i", threadID);  

    HINSTANCE hinst = LoadLibrary(_T("MyDLL.dll")); 

    if (hinst) { 
     typedef void (*Install)(unsigned long); 
     typedef void (*Uninstall)(); 

     Install install = (Install) GetProcAddress(hinst, "install"); 
     Uninstall uninstall = (Uninstall) GetProcAddress(hinst, "uninstall"); 

     install(threadID); 

     Sleep(20000); 

     uninstall(); 
    } 

    return 0; 
} 

答えて

13

三つの問題:

あなたがスレッドIDを使用する必要があるときには、プロセスIDを使用しています。

あなたHHOOKは、共有メモリに入る必要があります:

#pragma data_seg(".shared") 
HHOOK hhk = NULL; 
#pragma data_seg() 
#pragma comment(linker, "/SECTION:.shared,RWS") 
あなたが渡す必要が

あなたHHOOKCallNextHookExへ:

return CallNextHookEx(hhk, code, wParam, lParam); 
+1

GetWindowThreadProcessId()あなたが必要とするスレッドのIDを返します(その戻り値として) 。インラインアセンブラとReadProcessMemoryで何をしているのかは必要ではなく、ほとんど確実に動作しません。 – RichieHindle

+2

'hhk'を' 0'に初期化する必要があります。正しく共有されません。 – yoyoyoyosef

+0

@yoyoyoyosef:ありがとうございました。 – RichieHindle