有对hook熟悉的高手没?

thisworld 2009-10-30 11:02:25
<<windows核心编程》里有个hook messagebox的例子,为什么我自己写的程序弹出的MessageBox它没有hook到?而按照书里说的打开notepad.exe,写些东西再关闭,弹出的messagebox却能hook到。
开始我以为是因为我用的mfc写的程序的缘故(vc6.0),后来我试了下写了个简单的纯sdk的程序,它所弹出的messagebox居然一样hook不到。有高手知道是什么原因么?这与程序库(user32.dll)的静态编译没有什么关系吧?

我在mfc和纯sdk win32窗口程序里所调用的messagebox的方法如下:
MessageBox(NULL, "fail", "X", MB_OK);
MessageBoxW(NULL, L"ok", L"Z", MB_OK);
...全文
336 25 打赏 收藏 转发到动态 举报
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
lllyyy2403 2010-01-03
  • 打赏
  • 举报
回复
lz,CSDN的回答只能给个大概方向,具体还是要自己摸索的。
  • 打赏
  • 举报
回复
对楼主无言
cclk-1024 2009-12-29
  • 打赏
  • 举报
回复
需要把dll文件注入到exe文件中~!
thisworld 2009-12-07
  • 打赏
  • 举报
回复
都不肯帮忙,只好自己研究了,问题已解决,发现是修改IAT的时候失败了。
assicen 2009-11-08
  • 打赏
  • 举报
回复
把代码贴上来吧 你这样问 我们就跟盲人摸象一样

本来也怀疑你是HOOK错A/W了 结果我试了XP SP3的NOTEPAD.EXE 弹窗是用MessageBoxW的 所以你HOOK应该没错 你应该检查一下流程 具体情况你也没描述清楚

问你几个问题

你HOOK用的是DLL还是EXE?
远程HOOK NOTEPAD.EXE的时候 是怎么个实现过程?
HOOK自己的时候又是什么实现过程?

拿出来看看
MoXiaoRab 2009-11-08
  • 打赏
  • 举报
回复
我的代码你看了没
thisworld 2009-11-08
  • 打赏
  • 举报
回复
难道csdn真的找不到能帮我的人了!
guangmingdeshenju 2009-11-07
  • 打赏
  • 举报
回复
[Quote=引用 17 楼 nooning 的回复:]
这和你的HOOK及调用都有关

新的VS项目默认都是unicode,也就是都用W版的API

如果你的HOOK只针对A版,那就HOOK不到,如果你HOOK的是W那么A和W都可以HOOK到.
在NT系统里默认都是W(绝大部分),A版基本上都是把字符串转成WCHAR 再调用W版的

你HOOK MessageBoxW 就都可以HOOK到了.
[/Quote]

应该是你的hook函数类型设置问题
nooning 2009-11-07
  • 打赏
  • 举报
回复
这和你的HOOK及调用都有关

新的VS项目默认都是unicode,也就是都用W版的API

如果你的HOOK只针对A版,那就HOOK不到,如果你HOOK的是W那么A和W都可以HOOK到.
在NT系统里默认都是W(绝大部分),A版基本上都是把字符串转成WCHAR 再调用W版的

你HOOK MessageBoxW 就都可以HOOK到了.
thisworld 2009-11-06
  • 打赏
  • 举报
回复
代码比较多,我把我测试写的所有代码都打包了,期待高手帮助!

http://www.brsbox.com/filebox/down/fc/c5a38f0aa7f3454b75b9da4a728fc9d8
dong364 2009-11-06
  • 打赏
  • 举报
回复
我估计是你没有注入成功 贴代码吧
hnicypb 2009-11-06
  • 打赏
  • 举报
回复
贴代码看看
magic7004 2009-11-06
  • 打赏
  • 举报
回复
为什么我用同样的方法hook CreateProcess就可以呢?

楼住还是贴代码上来吧
waltsin 2009-11-06
  • 打赏
  • 举报
回复
你试试使用微软的Detours库,只Hook MessageBoxW就可以,不用Hook MessageBoxA,调用的时候也通过MessageBox调用,一般就能Hook到。能不能把那个程序的代码贴上来看一下
thisworld 2009-11-03
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 zoulie 的回复:]
做之前把你电脑上的安全软件关了,
在试试看下
[/Quote]

试了,但也是不行呀,你的那个程序只能hook住自己,其他都不能hook,连notepad弹出来的对话框都不能hook住呀。
MoXiaoRab 2009-11-02
  • 打赏
  • 举报
回复
你没试我的源码啊?
zoulie 2009-11-02
  • 打赏
  • 举报
回复
做之前把你电脑上的安全软件关了,
在试试看下
nevergone 2009-11-02
  • 打赏
  • 举报
回复
用 Rootkit Unhook检查一下你的HOOK 有没有成功.
如果HOOK成功, RKU 会显示出HOOK的类型以及模块, 你这里是IAT Modification.

fishion 2009-11-02
  • 打赏
  • 举报
回复
你判断是否成功加载的dll了没有
thisworld 2009-11-02
  • 打赏
  • 举报
回复
注入了的,我都加了log输出,有log文件生成了.
加载更多回复(5)
Windows是庞大复杂的系统。由于Windows并不公开源代码,我们在调试程序的时候,往往就调到自己未知的领域去了。有C代码,只能看到令人眼花缭乱的汇编指令和机器码。我曾对它们望而生畏,敬而远之。尤其在这个黑客、破解、病毒、木马横行的时代,如果作为安全软件的开发者,同样不能期盼病毒的作者提供可以阅读的高级语言代码。 如果那些东西,也和C语言一样亲切易懂,那多么好啊!这样的话,即便是Windows这样庞大复杂而且封闭的系统,或者是再诡异和隐蔽的破坏技术,至少只要我愿意去探索,对我来说就不再有秘密可言。 其实这个梦想并非不切实际。既然我们能读懂C代码,何以就不能读懂汇编呢?很多高手眼中,机器指令和C代码一样熟悉。 这本书并有系统地介绍Windows系统底层。但是我尝试寻找正确的方法和手段,为读者打开Windows底层知识宝库的大门,使读者可以在其中自由阅读,自己去获取所需知识。 目录概要: 入手篇 熟悉汇编 本书的第一部分,将帮助读者消除对汇编的恐惧,熟悉汇编。本部分包括第I-3章。稍显枯燥的是,它们和Windows内核无关,是纯C语言与汇编语言的关系的字节。如果读者已经精通汇编语言,并能顺利阅读汇编代码,请直接跳进本部分。 第1章 汇编指令与C语言 1.1 上机建立第一个工程 1.1.1 用Visual Studio创建工程 1.1.2 用Visual Studio查看新汇编代码 1.2 简要复习常用的汇编指令 1.2.1 堆栈相关指令 1.2.2 数据传送指令 1.2.3 跳转与比较指令 1.3 C函数的参数传递过程 第2章 C语言的流程和处理 2.1 C语言的循环反汇编 2.1.1 for循环 2.1.2 do循环 2.1.3 while循环 2.2 C 语言判断与分支的反汇编 2.2.1 if-else判断分支 2.2.2 switch-case判断分支 2.3 C语言的数组与结构 2.4 C语言的共用体和枚举类型 第3章 练习反汇编C语言程序 3.1 算法的反汇编 3.1.1 算法反汇编代码分析 3.1.2 算法反汇编阅读技巧 3.2 发行版的反汇编 3.3 汇编反C语言练习 基础篇 内核编程 本书的第二部分,是编写Windows内核程序缡耩方法的基础。本部分包括第4-7章,如果读者对Windows内核编程已经有一定的了解,可以跳过本部分;如果读者从未接触过Windows内孩编程,本部分将指导读者开始Windows内核编程,学会使用WDK,并熟悉内核编程的习惯与方法。 第4章 内核字符串与内存 4.1 字符串的处理 4.1.1 使用字符串结构 4 1 2 字符串的初始化 4.1.3 字符串的拷贝 4.1.4 字符串的连接 4.1.5 字符串的打印 4 2 内存与链表 4 2.1 内存的分配与释放 4.2.2 使用LIST_ENTRY 4.2.3 使用长长整型数据 4.2.4 使用自旋锁 第5章 文件与注册表操作 5.1 文件操作 5.1.1 使片OBJECT_ATTRIBUTES 5.1.2 打开和关闭文件 5.1.3 文件读,写操作 5.2 注册表操作 5.2.1 注册表键的打开 5.2.2 注册表值的读 5 2 3 注册表值的写 第6章 时间与线程 6.1 时间与定时器 6.1.1 获得当前滴答数 6.1.2 获得当前系统时问 6.1.3 使用定时器 6.2 线程与事件 6.2.1 使用系统线程 6.2.2 在线程中睡眠 6.2.3 使用同步事件 第7章 驱动、设备与请求 7.1 驱动与设备 7.1.1 驱动入口与驱动对象 7.1.2 分发函数和卸载函数 7 1 3 设备与符号链接 7.1.4 设备的安全创建 7,1.5 设备与符号链接的用户相关性 7.2 请求处理 7.2.1 IRP与 IO L_STACK_LOCATION 7 2.2 打开与关闭请求的处理 7.2.3 应用层信息传入 7.2.4 驱动层信息传出 探索篇 研究内核 本书的第三部分,开始探索Windows内核程序,并尝试阅读反汇编代码作为指引。本部分包括第8-10章。如果读者对Windows内棱编程已经有一定的了解,这一部分套比较有趣;如果读者从未接触过Windows内核编程,读者应该先学习第二部分。能自己编写内核程序并不意味着可以读懂内核,虽然反过来是一定成立的。读懂别人编写的有代码的程序,比自己编写更困难一些,但的确是值得的。 第8章 进入Windows内核 第9章 用C++编写的内核程序 第10章 继续探索Windows内核 深入篇 修改内核 这是本书的第四部分。读者已经尝试过探索Windows内核程序,并尝试阅读反汇编代码。那么接下来,必须掌握修改内核的方法。每一个Windows内核程序,都可以看做Windows内核本身的一个“补丁”。有时只需要独立存在,就能起到它的作用;有时却必须对已有的内核二进制代码进行部分修改。本部分包括第11—13章,主要介绍的是内核Hook。 第11章 机器码与反汇编引擎 第12章 CPU权限级与分页机制 第13章 开发Windows内核Hook 实战篇 实际开发 实战部分是本书最深入和复杂的一部分,包括第14-17章。为了让前面练习的成果,在实际应用中产生价值,在这部分我们补充更多的理论知识并尝试用它们去做一点什么。这一部分包括指令分析、硬件基础知识、内核Hook的实际开发练习,以及将完成一个用到内核Hook的有趣的实例,这个实例有助于计算机阻挡各种病毒和木马的侵袭。 此外,本部分遂包括特殊的一章,涉及如何巧妙地编写代码,来防止被其他不受欢迎的读者阅读。这与本书的主旨完全相反,正所谓物极必反。 第14章 反病毒、木马实例开发 第15章 Rootkit与HIPS 第16章 手写指令保护代码 第17章 用VMProtect保护代码

15,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 进程/线程/DLL
社区管理员
  • 进程/线程/DLL社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧