美文网首页
Detours 库使用(一)

Detours 库使用(一)

作者: 王大虾34 | 来源:发表于2017-02-04 16:23 被阅读248次

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查看目标程序是否已经注入我们的动态库。注入前:

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

相关文章

  • Detours 库使用(一)

    Detours是微软开发的一个函数库,可用于捕获系统API。Detours库的编译方法:http://blog.c...

  • HOOK如何用C++调用detours劫持WindowsAPI?

    00 detours detours是微软亚洲研究院出品的信息安全产品,用于劫持 可用Detours Expres...

  • Detours

    abc

  • DETOURS

    今天是看姐姐给自己加油的一天 非常非常非常开心 和朋友们吐槽惋惜了孟佳 不知道是不是剪的问题 开场solo比别的姐...

  • 使用微软的HOOK库

    Detours是微软开发的一个函数库,可用于捕获系统API。在用其进行程序开发之前,得做一些准备工作:一.下载De...

  • VS2017编译Detours

    1 将下载的Detours放到目录下:C:\Program Files (x86)\Microsoft Visua...

  • VS 2017 IDE compiler option" /pe

    在尝试用vs2017 ide编译detours的过程中,发现syelogd.exe居然编译不过。 经一番努力,终于...

  • Python解析IP地址CIDR的形式

    使用IPy库 使用netaddr库

  • pandas读取及存储MySQL

    一、工具 需要使用到的库 二、建立数据库连接 使用pymysql库 使用sqlalchemyl库 三、读取数据到D...

  • 3.7math库random库

    一、数学库及其使用 二、random库 随机数库及其使用: >>>from random import * >>>...

网友评论

      本文标题:Detours 库使用(一)

      本文链接:https://www.haomeiwen.com/subject/qftsittx.html