Detours 库使用(一)

Detours是微软开发的一个函数库,可用于捕获系统API。

Detours库的编译方法:http://blog.csdn.net/hewei0241/article/details/38326899

测试环境:win7 x86

PS:win x64 在注入的时候,所有测试程序是32位的。如果使用创建远程线程函数的方法来注入动态库,在win7 x64下,CreateRemoteThread会调用失败,错误码是5,就是没有权限访问。如果要在64位机器下使用,或许要google或者度娘研究下,或者使用其他注入的方法。

从微软官方下载Detours的源码,最终编译要得到一个detours.lib,用来Hook你要Hook的系统API。

这次的Demo是要Hook Socket编程中的send和recv函数。在自己的拦截函数里,把发送的内容保存到本地文件中,把内容记录下来。所以Demo公需要4个工程文件:

(1)一个目标程序,通过Socket连接发送消息,还需要一个辅助的服务端。

(2)一个注入程序,把动态库注入到目标程序

(3)一个Hook了目标函数,send和recv的动态库,使用Detourts库。

这是测试Demo的地址:http://download.csdn.net/detail/wzf906819823/8980741

1.要使用Detours库,导入detours.h头文件和链接detours.lib静态库 。使用这个库提供的API Hook系统API,例如在这个例子中的send和recv函数。

2.注入程序,遍历目标程序,把动态库注入目标程序。注入目标程序的方法是创建远程线程来加载这个动态库,动态库里Hook了send和recv这两个函数。在这两个函数里,把用户发送的内容保存到了文件里。

3.可以用Process Explorer查看目标程序是否已经注入我们的动态库。注入前:


注入后:发现DetoursTest_Client.exe这个进程内已经注入了我们自己的动态库,DetoursTest_HookDll.dll.


  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值