如何使用Windbg自动抓取禁止使用调试器程序的dump

前面我们讲到了如何使用Windbg调试禁止使用调试器的程序,但是如果该程序并不是每次都会发生异常,而我们又想抓取异常的第一现场,每次启动程序的时候都输入命令太麻烦了,本文主要讲述如何自动处理这个问题。

 

1. 使用IFEO自动加载调试器

    注册表HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows NT/CurrentVersion/Image File Execution Options
中新建Key,Key名称为被调试的程序名称,如TestCrash.exe
   在该Key下新建一个字符串项,名称为Debugger,内容为"D:/Program Files/Debugging Tools for Windows (x86)/windbg.exe"
   此时启动TestCrash.exe,Windbg会自动启动并附加到该进程。IFEO可以参考 http://support.microsoft.com/?kbid=824344

2. 调试器加载时自动执行命令,修改peb+2的内存标志

    我们的目标是想在启动时自动执行一些命令,修改内存值,使程序可以继续调试,因此修改注册表中Debugger的内容,是Windbg带上命令参数:

"D:/Program Files/Debugging Tools for Windows (x86)/windbg.exe" -c "~0s;eb poi(fs:18:30)+2 0; g"

 

3. 程序运行,Crash的第一现场可以被Windbg抓获了

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值