키보드 후킹이란 말 그대로 키가 눌렸을 때 그 키의 정보를 가지고 오거나 수정 하는 것을 말합니다.
흔히 해킹기법으로 잘 알려졌지만 쓰기에 따라서 굉장히 유용한 기능(?)이죠.
특정 키를 막거나 키보드 메크로를 만들거나 할 때 많이 사용합니다.
먼저 후킹 됐을때 사용할 함수를 정의합니다.
'WinAPI'인 'LowLevelKeyboardProc'를 정의하면 됩니다.
(참고 : MS Learn - LowLevelKeyboardProc 함수 )
HHOOK hKeyboardHook;
LRESULT CALLBACK LowLevelKeyboardProc(int nCode, WPARAM wParam, LPARAM lParam)
{
PKBDLLHOOKSTRUCT p;
if (nCode == HC_ACTION)
{
p = (PKBDLLHOOKSTRUCT) lParam;
if (((p->vkCode == VK_LWIN) || (p->vkCode == VK_RWIN))
|| ( p->flags & LLKHF_ALTDOWN)
|| (p->vkCode == VK_TAB)
)
return 1;
}
return CallNextHookEx(hKeyboardHook, nCode, wParam, lParam);
}
1번 줄 : 'HHOOK hKeyboardHook' 설치된 훅의 인스턴스를 저장할 변수입니다.
11번 줄: 넘어온 키 정보입니다.
이후 코드는 넘어온 키 정보를 사용하는 코드입니다.
후킹을 하려면 훅을 후킹 할 대상에 연결해야 합니다.
그때 사용하는 함수가 'SetWindowsHookEx'입니다.
hKeyboardHook = SetWindowsHookEx(WH_KEYBOARD_LL, LowLevelKeyboardProc, hInst, 0); // hook 설치
훅을 제거할 때는
UnhookWindowsHookEx(hKeyboardHook); //제거
hKeyboardHook = NULL;
(이 예제코드는 'int WINAPI WinMain(HINSTANCE hInst, HINSTANCE hPrevInst, LPSTR lpszCmdParam, int nCmdShow)' 에서 사용할 때의 예제입니다.)
컴파일했는데 'PKBDLLHOOKSTRUCT'를 못 찾는 에러가 난다면
#define _WIN32_WINNT 0x0400
를 추가하여 막을수 있습니다.
이 방법으로 Alt + Del + Ctrl 만 빼고 모든 시스템키까지 막을 수 있습니다....
(정작 중요한 건 Alt + Del + Ctrl 데 말입니다-_-;;;)