为了显示效果,在钩子的DLL中我们会获取挂钩函数的窗体句柄,这里的主程序窗体名为"TestMain",通过FindWindow查找。

KeyBoardHook.dll代码

  1. library KeyBoardHook;
  2. { Important note about DLL memory management: ShareMem must be the
  3. first unit in your library's USES clause AND your project's (select
  4. Project-View Source) USES clause if your DLL exports any procedures or
  5. functions that pass strings as parameters or function results. This
  6. applies to all strings passed to and from your DLL--even those that
  7. are nested in records and classes. ShareMem is the interface unit to
  8. the BORLNDMM.DLL shared memory manager, which must be deployed along
  9. with your DLL. To avoid using BORLNDMM.DLL, pass string information
  10. using PChar or ShortString parameters. }
  11. uses
  12. SysUtils,Windows,Messages,
  13. Classes;
  14. var
  15. fHook:HHOOK;
  16. //执行挂钩程序的窗体句柄
  17. CallHandle:HWND;
  18. {$R *.res}
  19. //回调过程
  20. function HookProc(code:Integer;wParam:WPARAM;lParam:LPARAM):LRESULT;stdcall;
  21. var
  22. processid:Cardinal;
  23. begin
  24. //如果有键盘动作
  25. if code = HC_Action then
  26. begin
  27. //获取注入进程的进程id
  28. processid := GetCurrentProcessId;
  29. //如果CallHandle,则查找TestMain窗体句柄
  30. if CallHandle = 0 then
  31. CallHandle := FindWindow(nil,'TestMain');
  32. //获取按键状态 小于0表示按下,如果不做判断,按键按下或抬起都会执行SendMessage
  33. //下面发送WM_USER+101消息,此消息可以用自定义的消息标识发送
  34. if GetKeyState(wParam) < 0 then
  35. SendMessage(CallHandle,WM_USER+101,wParam,processid);
  36. end
  37. else
  38. //下一个钩子
  39. Result := CallNextHookEx(fHook,code,wParam,lParam);
  40. end;
  41. procedure SetHook;stdcall;
  42. begin
  43. //挂钩,这里没有做挂钩失败的提示
  44. fHook := SetWindowsHookEx(WH_KEYBOARD,@HookProc,HInstance,0);
  45. end;
  46. procedure StopHook;stdcall;
  47. begin
  48. //摘钩
  49. if fHook <> 0 then
  50. UnhookWindowsHookEx(fHook);
  51. end;
  52. exports
  53. SetHook name 'SetHook',
  54. StopHook name 'StopHook';
  55. begin
  56. //初始CallHandle为0
  57. CallHandle := 0;
  58. end.

TestKeyBoardHook主程序代码

  1. {
  2. 此窗体用来执行挂钩,为了方便起见,我们把系统的按键返回到该窗体的Memo组件中进行
  3. 显示,所以在dll中,做了获取主窗体的句柄的工作,以便发消息给主窗体,告诉它是哪个
  4. 按键被按下
  5. }
  6. unit TestMain;
  7. interface
  8. uses
  9. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  10. Dialogs, StdCtrls,TlHelp32;
  11. type
  12. TfrmTestMain = class(TForm)
  13. Memo1: TMemo;
  14. btn_SetHook: TButton;
  15. btn_StopHook: TButton;
  16. procedure btn_SetHookClick(Sender: TObject);
  17. procedure btn_StopHookClick(Sender: TObject);
  18. procedure FormClose(Sender: TObject; var Action: TCloseAction);
  19. private
  20. { Private declarations }
  21. procedure WndProc(var Message: TMessage);override;
  22. public
  23. { Public declarations }
  24. end;
  25. var
  26. frmTestMain: TfrmTestMain;
  27. implementation
  28. procedure SetHook;stdcall;external 'KeyBoardHook';
  29. procedure StopHook;stdcall;external 'KeyBoardHook';
  30. {$R *.dfm}
  31. procedure TfrmTestMain.btn_SetHookClick(Sender: TObject);
  32. begin
  33. SetHook;
  34. end;
  35. procedure TfrmTestMain.btn_StopHookClick(Sender: TObject);
  36. begin
  37. StopHook;
  38. end;
  39. procedure TfrmTestMain.WndProc(var Message: TMessage);
  40. var
  41. hSnapShot:THandle;
  42. pEntry:TProcessEntry32;
  43. find:Boolean;
  44. proName:string;
  45. begin
  46. if Message.Msg = WM_USER+101 then
  47. begin
  48. //创建进程快照
  49. hSnapShot := CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
  50. pEntry.dwSize := SizeOf(pEntry);
  51. find := Process32First(hSnapShot,pEntry);
  52. while find do
  53. begin
  54. //取进程名字
  55. proName := pEntry.szExeFile;
  56. if pEntry.th32ProcessID = Message.LParam then Break;
  57. find := Process32Next(hSnapShot,pEntry);
  58. end;
  59. Memo1.Lines.Add('进程:' + proName + ',ID:' +IntToStr(Message.LParam)+'按下按键:'+Chr(Message.WParam));
  60. CloseHandle(hSnapShot);
  61. end;
  62. inherited;
  63. end;
  64. procedure TfrmTestMain.FormClose(Sender: TObject;
  65. var Action: TCloseAction);
  66. begin
  67. StopHook;
  68. end;
  69. end.

运行结果

http://blog.csdn.net/bdmh/article/details/6124127

全局键盘钩子(WH_KEYBOARD)的更多相关文章

  1. [转载] 全局键盘钩子(WH_KEYBOARD)

    为了显示效果,在钩子的DLL中我们会获取挂钩函数的窗体句柄,这里的主程序窗体名为"TestMain",通过FindWindow查找. KeyBoardHook.dll代码 libr ...

  2. 使用raw input 代替全局键盘钩子

    //关于raw input 请查看msdn https://msdn.microsoft.com/en-us/library/windows/desktop/ms645536%28v=vs.85%29 ...

  3. c#-全局键盘钩子

    using System; using System.Collections.Generic; using System.Text; using System.Windows.Forms; using ...

  4. 【VB6】全局键盘钩子

    基本也没啥好说的,不要用到木马及恶意程序中是以前从VB.NET程序改到VB6的,阉割了一些功能,只提供键盘Hook功能想要截获热键可以在处理函数中返回1,里面有示例 下载地址 http://pan.b ...

  5. C#简单鼠标键盘钩子KMHook

    简介:由三个文件构成Pinvo.cs.KeyboardHook.cs.MouseHook.cs Pinvo.cs 是KeyboardHook与MouseHook需要的一些常量消息的定义 Keyboar ...

  6. 2.添加键盘钩子。向进程中注入dll

    学习笔记 1.首先要建立mfc的动态链接库.在def文件中放入要导出的函数名. 2.添加函数如下 //安装钩子 //HHOOK SetWindowsHookEx( // int idHook,//钩子 ...

  7. C#实现键盘钩子

    前言: 因为项目中需要使用到快捷键,所以上网找资料了解关于快捷键的实现技术,于是有了键盘钩子的使用学习.在网上了解到,键盘钩子其实只是很多种钩子中的其中一种.所谓钩子:请看下面关于钩子的描述(来自百度 ...

  8. C#鼠标键盘钩子

    using System;using System.Collections.Generic; using System.Reflection; using System.Runtime.Interop ...

  9. C#全局键盘监听(Hook)

    一.为什么需要全局键盘监听? 在某些情况下应用程序需要实现快捷键执行特定功能,例如大家熟知的QQ截图功能Ctrl+Alt+A快捷键,只要QQ程序在运行(无论是拥有焦点还是处于后台运行状态),都可以按下 ...

随机推荐

  1. 深刻理解Oracle数据库的启动和关闭 .

    Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对于大多数Oracle DBA来说,启动和 ...

  2. Elevator(hdoj 1008)

    Problem Description The highest building in our city has only one elevator. A request list is made u ...

  3. Redis 数据库的安装

    安装redis真的是简单到不行了,三条命令就可以完成. 1.下载redis: 001.http://redis.io/ 002.也可以在我的网盘下载https://yunpan.cn/crSUX6aS ...

  4. linux function

    #!/bin/bash function sayHello() { #这里的{ 和它前面的)之间可以没有空格 echo "Hello $1" } sayHello 'Neeky'

  5. 一步一步学python(四) - 字典

    1.字典的使用 创建字典:phonebook = {'Alice': '1234' , 'Beth':'9120'} 2.dict函数 >>>items = [('name','Gu ...

  6. js跑马灯效果

    function nextPage() {           /*         克隆第一张图片并添加到box后         box前移一张图片的距离动画         动画回调里把box的 ...

  7. 快速配置 Samba 将 Linux 目录映射为 Windows 驱动器

    原文链接 samba client ubuntu redhat ubuntu gui tools 1,列出某个IP地址所提供的共享文件夹 smbclient -L 198.168.0.1   2,在s ...

  8. mariadb启动

    systemctl start mariadb.service #启动MariaDBsystemctl stop mariadb.service #停止MariaDBsystemctl restart ...

  9. javascript数据类型、初始化

    Javascript数据类型有6种: 数值型数据类型(Number): 字符串(String): 布尔型数据(Boolean): 对象数据(Object): 空(Null): 未定义(Undefine ...

  10. Kinect for windows 破解 一,简单的体感超级玛丽

    背景知识 1.  游戏模拟器:现在有很多模拟器,让我们可以在PC上玩红白机,PS上的游戏.本破解用的FC 红白机模拟器.网上有很多地方可以下载.注意语言要和你的操作系统一致. 2.  按键模拟器:本破 ...