19,504
社区成员
发帖
与我相关
我的任务
分享
#include "stdafx.h"
#include "KeyDetProc.h"
#define DEBUG_CODE 1
#define WH_KEYBOARD_LL 20
typedef LRESULT (WINAPI *_CallNextHookEx)(HHOOK, int, WPARAM, LPARAM);
typedef LRESULT (WINAPI *_UnhookWindowsHookEx)(HHOOK);
typedef LRESULT (CALLBACK* HOOKPROC)(int code, WPARAM wParam, LPARAM lParam);
typedef HHOOK (WINAPI *_SetWindowsHookExW)(int, HOOKPROC, HINSTANCE, DWORD);
static _CallNextHookEx CallNextHookEx;
static _SetWindowsHookExW SetWindowsHookEx;
static _UnhookWindowsHookEx UnhookWindowsHookEx;
typedef struct {
DWORD vkCode;
DWORD scanCode;
DWORD flags;
DWORD time;
ULONG_PTR dwExtraInfo;
} KBDLLHOOKSTRUCT, *PKBDLLHOOKSTRUCT;
//LRESULT __declspec(dllexport)__stdcall CALLBACK KeyboardProc(int nCode,WPARAM wParam,LPARAM lParam)
extern "C" LRESULT CALLBACK KeyboardProc(int nCode,WPARAM wParam,LPARAM lParam)
{
RETAILMSG(DEBUG_CODE,(L"hook KeyboardProc\r\n"));
KBDLLHOOKSTRUCT *pkbhs = (KBDLLHOOKSTRUCT *) lParam;
if(wParam == WM_KEYUP)
{
RETAILMSG(DEBUG_CODE,(L"hook key up\r\n"));
}
if(wParam == WM_KEYDOWN)
{
RETAILMSG(DEBUG_CODE,(L"hook key down\r\n"));
}
RETAILMSG(1,(L"Get a Key\r\n"));
return CallNextHookEx(NULL,nCode,wParam,lParam);
}
HINSTANCE g_hHookApiDLL = NULL;
HINSTANCE hins;
HHOOK g_hInstalledLLKBDhook = NULL;
//BOOL ActivateKBHook(HINSTANCE hInstance, HOOKPROC LLKeyboardHookCallbackFunction)
BOOL KeyDetProc_InsHook(void)
{
RETAILMSG(DEBUG_CODE,(L"DLL:KeyDetProc_InsHook \r\n"));
//RETAILMSG(DEBUG_CODE,(L"进入ActivateKBHook\r\n"));
//we need to manually load these standard Win32 API calls
//MSDN states that these aren't supported in WinCE
SetWindowsHookEx = NULL;
CallNextHookEx = NULL;
UnhookWindowsHookEx = NULL;
//now load the coredll.dll
g_hHookApiDLL = LoadLibrary(_T("coredll.dll"));
if(g_hHookApiDLL == NULL)
{
//something is awfully wrong
//the dll has to be present
RETAILMSG(DEBUG_CODE,(L"load coredll.dll fail\r\n"));
return false;
}
else
{
RETAILMSG(DEBUG_CODE,(L"LoadLibrary coredll.dll ok \r\n"));
//load the SetWindowsHookEx API call
//the SetWindowsHookEx function installs an application-defined hook procedure into a hook chain.
//You would install a hook procedure to monitor the system for certain types of events.
//here we use use the hook to monitor kyeboard events
SetWindowsHookEx = (_SetWindowsHookExW)GetProcAddress(g_hHookApiDLL, _T("SetWindowsHookExW"));
if(SetWindowsHookEx == NULL)
{
//this means that MS has really stopped supporting this API in WinCE
RETAILMSG(DEBUG_CODE,(L"获取SetWindowsHookExW地址失败\r\n"));
return false;
}
else
{
//install the KB hook
//the hande needs to be saved for default processing of the events and to uninstall the hook, once we are done with it
hins = AfxGetInstanceHandle();
g_hInstalledLLKBDhook = SetWindowsHookEx(WH_KEYBOARD_LL, KeyboardProc, hins, 0);
if(g_hInstalledLLKBDhook == NULL)
{
int re;
re=GetLastError();
RETAILMSG(DEBUG_CODE,(L"SetWindowsHookEx失败 %d \r\n",re));
return false;
}
}
//load CallNextHookEx() API call
//the CallNextHookEx function passes the hook information to the next hook procedure in the current hook chain.
//we use this call for default processing of events.
CallNextHookEx = (_CallNextHookEx)GetProcAddress(g_hHookApiDLL, _T("CallNextHookEx"));
if(CallNextHookEx == NULL)
{
RETAILMSG(DEBUG_CODE,(L"获取_CallNextHookEx地址失败\r\n"));
return false;
}
//load UnhookWindowsHookEx() API
//the UnhookWindowsHookEx function removes a hook procedure installed in a hook chain by the SetWindowsHookEx function.
//we use this call to unistall the hook.
UnhookWindowsHookEx = (_UnhookWindowsHookEx)GetProcAddress(g_hHookApiDLL, _T("UnhookWindowsHookEx"));
if(UnhookWindowsHookEx == NULL)
{
RETAILMSG(DEBUG_CODE,(L"获取_UnhookWindowsHookEx地址失败\r\n"));
return false;
}
}
//all the APIs are loaded and the application is hooked
return true;
}
BOOL KeyDetProc_UnHook(void)
{
UnhookWindowsHookEx(g_hInstalledLLKBDhook);
RETAILMSG(1,(L"unhook kb ok\r\n"));
return TRUE;
}
LRESULT CALLBACK KeyboardProc(int nCode,WPARAM wParam,LPARAM lParam)
{
// RETAILMSG(DEBUG_CODE,(L"hook KeyboardProc\r\n"));
KBDLLHOOKSTRUCT *pkbhs = (KBDLLHOOKSTRUCT *) lParam;
if(wParam == WM_KEYUP)
{
RETAILMSG(DEBUG_CODE,(L"hook key up\r\n"));
}
if(wParam == WM_KEYDOWN)
{
RETAILMSG(DEBUG_CODE,(L"hook key down\r\n"));
}
RETAILMSG(1,(L"hook Get a Key\r\n"));
return 1L;//CallNextHookEx(NULL,nCode,wParam,lParam);
}
为什么这样子改一下就没有内存泄露了,wParam == WM_KEYUP和if(wParam == WM_KEYDOWN) 为什么都进入不了?