| 网站首页 | 校园文化 | 视频在线 | 搞笑图片 | 廊坊师院 | 师院风光 | 商家联盟 | 关于我们 | 下载 | 学习考试 | 创业管理 | 求职相关 | 实用文档 | 留言 | 
您现在的位置: 廊坊师范学院最大网络交流平台 >> 实用文档 >> 师院论文 >> 计算机论文 >> 计算机应用 >> 文章正文 今天是:
在Windows系统中用VC++实现钩子机制
作者:佚名 文章来源:不详 点击数: 更新时间:2007-9-12 23:33:57

摘要:本文分析了在Windows环境下,什么是钩子程序以及怎样用VC++实现一个钩子机制的关键技术。最后,用一个可以截获鼠标信息的完整程序说明了这些问题。

关键词:钩子程序,DLL,消息截获

一.      什么是钩子。
Windows系统是建立在事件驱动的机制上的,说穿了就是整个系统都是通过消息的传递来实现的。钩子(hook)是一种特殊的消息处理机制,钩子可以监视系统或进程中的各种事件消息,截获发往目标窗口的消息并进行处理。这样,我们就可以在系统中安装自定义的钩子,监视系统中特定事件的发生,完成特定的功能,比如截获键盘、鼠标的输入,屏幕取词,日志监视等等。
钩子的种类很多,每种钩子可以截获并处理相应的消息,如键盘钩子可以截获键盘消息,外壳钩子可以截取、启动和关闭应用程序的消息等。钩子可以分为线程钩子和系统钩子, 线程钩子监视指定线程的事件消息, 系统钩子监视系统中的所有线程的事件消息。因为系统钩子会影响系统中所有的应用程序,所以钩子函数必须放在独立的动态链接库(DLL) 中。

二.      实现钩子机制的几个关键技术。
1.      windows的钩子程序,需要用到几个sdk中的api函数。下面列出这几个函数的原型及说明:
hhook setwindowshookex(int idhook,hook_proc lpfn,hinstance hmod,dword dwthreadid);
参数说明如下:
  idhook:钩子的类型
  lpfn:钩子处理函数地址
  hmod:包含钩子函数的模块句柄
  dwthreadid:钩子的监控线程
函数说明:函数将在系统中挂上一个由idhook指定类型的钩子,监控并处理相应的特定消息。
bool unhookwindowshookex(hhook hhk);
函数说明:函数将撤销由hhk指定的钩子。
lresult callnexthookex( hhook hhk, int ncode,wparam wparam,lparam lparam );
函数说明:函数将消息向下传递,下一个钩子处理将截获这一消息。
2.      由于钩子的处理涉及到模块及进程间的数据地址问题,一般情况是把钩子整合到一个动态链接库(dll)中,VC中有三种形式的MFC DLL可供选择,即Regular statically linked to MFC DLL(标准静态链接MFC DLL)、Regular using the shared MFC DLL(标准动态链接MFC DLL)以及Extension MFC DLL(扩展MFC DLL)。第一种DLL在编译时把使用的MFC代码链接到DLL中,执行程序时不需要其他MFC动态链接类库的支持,但体积较大;第二种DLL在运行时动态链接到MFC类库,因而体积较小,但却依赖于MFC动态链接类库的支持;这两种DLL均可被MFC程序和Win32程序使用。第三种DLL的也是动态连接,但做为MFC类库的扩展,只能被MFC程序使用。
另外,要设立一个全局数据共享数据段,以存贮一些全局变量,保留上次钩子消息事件发生时的状态。
3.      Win32 DLL的入口和出口函数都是DLLMain。只要有进程或线程载入和卸载DLL时,都会调用该函数,其原型是:
  BOOL WINAPI DllMain(HINSTANCE hinstDLL,DWORD fdwReason, LPVOID lpvReserved); 其中,第一个参数表示DLL的实例句柄;第三个参数系统保留;第二个参数指明了当前调用该动态连接库的状态,它有四个可能的值:DLL_PROCESS_ATTACH(进程载入)、DLL_THREAD_ATTACH(线程载入)、DLL_THREAD_DETACH(线程卸载)、DLL_PROCESS_DETACH(进程卸载)。在DLLMain函数中可以通过对传递进来的这个参数的值进行判别,根据不同的参数值对DLL进行必要的初始化或清理工作。由于在Win32环境下,所有进程的空间都是相互独立的,这减少了应用程序间的相互影响,但大大增加了编程的难度。当进程在动态加载DLL时,系统自动把DLL地址映射到该进程的私有空间,而且也复制该DLL的全局数据的一份拷贝到该进程空间,每个进程所拥有的相同的DLL的全局数据其值却并不一定是相同的。当DLL内存被映射到进程空间中,每个进程都有自己的全局内存拷贝,加载DLL的每一个新的进程都重新初始化这一内存区域,也就是说进程不能再共享DLL。因此,在Win32环境下要想在多个进程中共享数据,就必须进行必要的设置。一种方法便是把这些需要共享的数据单独分离出来,放置在一个独立的数据段里,并把该段的属性设置为共享,建立一个内存共享的DLL。

三.      用钩子机制实现截获鼠标左右键按压次数。
   建立钩子程序时需要把钩子处理整合到动态链接库中,所以例程中需要建立两个project。
1.      钩子处理动态链接库
(1)      选择mfc appwizard(dll)创建一个新project,命名为“spy”。
(2)      选择mfc extension dll类型。
(3)      创建一个新的头文件,命名为“hook.h”,修改它的代码如下:
extern "C" LRESULT CALLBACK mouseproc(int code,WPARAM wparam,LPARAM lparam); //钩子处理函数
extern "C" bool WINAPI starthook(); //启动钩子函数
extern "C" bool WINAPI stophook(); //撤销钩子函数
extern "C" int WINAPI getresultl(); //取得鼠标左键单击次数的函数
extern "C" int WINAPI getresultr(); //取得鼠标右键单击次数的函数
(4)      修改spy.cpp程序代码如下:
#include "hook.h"    //包含头文件hook

#pra

[1] [2] [3] 下一页


文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    高校无厘精彩推荐
    固顶文章 校花扎堆!大学男生最向往的女生
    普通文章 有调查称女大学生未婚同居者62.4
    普通文章 网友公认纯美校花 今成为北影大一
    普通文章 大学各系的接吻方式
    普通文章 中国高校十大荒唐事件 从象牙塔到
    普通文章 “图说八荣八耻”宣传画进校园
    普通文章 图文:大学校园内的性学讲座
    普通文章 中国青年DV大赛-激扬互动视界
    普通文章 男子在校园内放飞99只蝴蝶求爱
    普通文章 让女生流口水的绝版帅哥

    高校动态
    固顶文章 廊坊师范学院2007年本科新生入学
    普通文章 大一新生流行高校论坛虚拟报到老
    普通文章 两名在校大学生借环保公益广告创
    普通文章 北大学生告微软侵隐私 称其程序收
    普通文章 贫困大学生因恋爱心理扭曲 持枪杀
    普通文章 大学四年,我没有谈过一次恋爱
    普通文章 大二学生对话新生:恋爱放纵不是大
    普通文章 大学新生军训强制女生剪短头发遭
    普通文章 大学新生军训强制女生剪短头发遭
    普通文章 找关系开发人脉 85后大学新生打探

     

    最 新 热 门 最 新 推 荐 相 关 文 章
    基于Linux内核的键盘模拟…
    改善嵌入式Linux实时性能…
    于PCI9656设备驱动程序的…
    使用http协议和winsocka…
    使用indy的IdTcpServer,…
    windowsnt环境下fddi网卡…
    windowsnt环境下fddi网卡…
    windows nt环境下fddi网…
    用Windows终端仿真程序实…
    Pro/Engineer二次开发关…
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 关于我们 | 友情链接 | 发展历程 | 用户留言 | 管理登录 | 
    420Studio