api hook时机问题

rageliu 2008-08-22 10:52:00
要实现在进程加载完但未开始执行时完成api hook,传统的远线程注入和SetWindowsHookEx注入钩子等方式就不适合了,大家有什么好的方式,我初步想到的几点:

1。注册表HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Windows键的AppInit_DLLs,在dll的入口处hook
2。替换系统dll,如user32,在自己的user32里完成hook
3。ring0对CreateProcess这类型函数的hook处理

上面几种方式,要处理的地方很多。大家有什么方法,给我些建议,3Q
...全文
144 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
cnzdgs 2008-08-22
  • 打赏
  • 举报
回复
1。注册表HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Windows键的AppInit_DLLs,在dll的入口处hook
这个是用户级最方便的方法了,不过有极少数特殊的程序不会加载,可以借助其它方法(例如Hook CreateProcess)让这类进程加载DLL。

2。替换系统dll,如user32,在自己的user32里完成hook
要替换系统的文件不容易,系统在运行过程中这些文件都是被使用的,无法替换,而且系统会自动检查这些文件,发现被替换了会自动还原。

3。ring0对CreateProcess这类型函数的hook处理
如果在内核级处理,Hook创建进程是不行的,而且由内核来LoadLibrary也不合理,应该直接针对你想要拦截的操作。
rageliu 2008-08-22
  • 打赏
  • 举报
回复
windows核心编程 第22章第八节
也就是这种方式:http://bbs.pediy.com/showthread.php?t=59746
rageliu 2008-08-22
  • 打赏
  • 举报
回复
如果3级有8错的方式可以搞定,个人偏向3级。因为稳定性还是比较重要的

如若CreateProcess挂起方式,又以什么方式注入为佳?
吹泡泡的小猫 2008-08-22
  • 打赏
  • 举报
回复
用驱动是最好的方法,AppInit_DLLs就不要想了,反病毒软件会把你的程序当病毒杀掉的
Amuro1987218 2008-08-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 rageliu 的回复:]
明白楼上的意思,

http://www.osdiy.com/Blog/article.asp?id=14
[/Quote]

打的很准.

CreateProcess HOOK也不错,加载后挂起主现成住进去再急活
ycoder 2008-08-22
  • 打赏
  • 举报
回复
mark
zhoujianhei 2008-08-22
  • 打赏
  • 举报
回复
3。ring0对CreateProcess这类型函数的hook处理
rageliu 2008-08-22
  • 打赏
  • 举报
回复
明白楼上的意思,

http://www.osdiy.com/Blog/article.asp?id=14
Amuro1987218 2008-08-22
  • 打赏
  • 举报
回复
Advapi32.dll入口处挂自己的DLL
rageliu 2008-08-22
  • 打赏
  • 举报
回复
测试通过,谢谢大家

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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