OD调试一个小程序的思考总结
2016-04-23 10:06
453 查看
最近用OD调试了一些小程序,有一些感悟,和大家分享一下
我用了一个多窗口的的程序(软件的试用),对如何去掉弹窗提供一些自己的看法,为大家提供一些思路
首先单步调试,会出现3个弹窗
1.通过对反汇编代码的分析,发现一个关键跳je,我们将je跳转改为jmp无条件跳转,使其直接跳过弹窗的程序
2.修改窗口句柄的值,学习过win32的人都知道,hOwner是一个父窗口的句柄,将他的值改为push 0x1,使他的子窗口失效
3.修改PE文件,alt+m进入内存映射的窗口并双击PE文件的内部
向下寻找,发现第一个窗口的入口地址
记下他的地址4000E8,alt+c返回到我们刚才的界面,,找到数据窗口crtl+g修改到我们要的PE头文件地址4000E8,即程序的入口地址
找到后对他值进行修改,修改为要跳转到窗口的地址401024,注意,修改的顺序为从右到左
保存后重启会发现第一个窗口直接跳过
4.对标志寄存器的修改 Z/O/F使其发生跳转或者不跳转,这个也很重要,但在本程序里没有涉及
5.最直接的方法,直接nop使其不跳转
我只是对破解提供一些思路,而且只是破掉了一个弹窗,希望能对大家有帮助,如有问题,还请大家多多提意见
我用了一个多窗口的的程序(软件的试用),对如何去掉弹窗提供一些自己的看法,为大家提供一些思路
首先单步调试,会出现3个弹窗
1.通过对反汇编代码的分析,发现一个关键跳je,我们将je跳转改为jmp无条件跳转,使其直接跳过弹窗的程序
2.修改窗口句柄的值,学习过win32的人都知道,hOwner是一个父窗口的句柄,将他的值改为push 0x1,使他的子窗口失效
3.修改PE文件,alt+m进入内存映射的窗口并双击PE文件的内部
向下寻找,发现第一个窗口的入口地址
记下他的地址4000E8,alt+c返回到我们刚才的界面,,找到数据窗口crtl+g修改到我们要的PE头文件地址4000E8,即程序的入口地址
找到后对他值进行修改,修改为要跳转到窗口的地址401024,注意,修改的顺序为从右到左
保存后重启会发现第一个窗口直接跳过
4.对标志寄存器的修改 Z/O/F使其发生跳转或者不跳转,这个也很重要,但在本程序里没有涉及
5.最直接的方法,直接nop使其不跳转
我只是对破解提供一些思路,而且只是破掉了一个弹窗,希望能对大家有帮助,如有问题,还请大家多多提意见
相关文章推荐
- iOS开发之微信自动抢红包功能
- 微信公众号支付失败的各种原因
- discuz 微信扫描论坛二维码提示“接口错误(ERR05)”
- 微信公众号如何做情感营销?
- 微信学习_01_开发环境搭建
- 实现微信布局的四种方式(一)
- 微信公众号第三方开发之三创建一键登录页授权给第三方平台
- Java公众号推荐 - BeJavaGod
- 判断浏览器(微信、微博、QQ)、操作系统、横竖屏等
- 培训机构微信在线报名
- 微信支付后默认关注公众号
- iOS- 微信支付 (服务器调起支付 )以及回调不成功的原因 不看后悔
- 微信支付:curl出错,错误码:60
- 微信刷步の悦动圈
- 微信电脑版2016 v2.0.0.80 官方正式版
- 毕设 微信分享
- file_get_contents微信头像等待时间过长的原因
- Android支付——微信支付总结
- 多个域名使用微信获取用户信息的解决办法
- 关于手机微信的聊天记录在手机中的存放位置及关系