【逆向工程核心原理】第11章笔记——视频讲座(去消息框)

一.运行Tut.ReverseMe1.exe

  1. 摆脱烦人设定

在这里插入图片描述

并找到注册码

在这里插入图片描述

二.分析

目标:去除消息框

  1. 调用API目录:
    在这里插入图片描述

  2. 找到要调用的rctMsgBox,共有4处。
    右击——set breakpoint on every call to rctMsgBox设置断点
    在这里插入图片描述
    设置成功,按F9运行。
    在这里插入图片描述
    :若是错误显示不出四个,可以把一些临时文件给删除。
    找到view——breakpoints——disabled,全部激活。
    在这里插入图片描述

观察到程序运行到402cFE停下来。
在这里插入图片描述
继续运行,弹出消息框,选择确定,出现主画面,按Nag:又会跑到2CFE.
观察EAX为00000001,说明都是相同的运行代码,所以只要对一处打补丁即可。

三. 打补丁(1):去除消息框

(1)第一次尝试:
在这里插入图片描述
修改完成后运行程序,发现没反应。失败。
原因:没有正确处理rctMsgBox函数的返回值(EAX寄存器)
(2)第二次尝试:
在这里插入图片描述
运行程序后发现成功去除消息框。
(3)第三次尝试
在402C17处改为RETN 4;
在这里插入图片描述
成功。

四. 查看402c17函数的参数个数

找到2CFE指令所处函数:发现是402C17
在这里插入图片描述
给402C17添加断点,重新启动。
F9运行,观察右下角窗口,确认函数的起始代码存储在栈中的返回地址(7401E5A9)
在这里插入图片描述
跳转到7401E5A9,找到调用指令7401E5A7,设置断点
在这里插入图片描述
运行到7401E5A7,观察到EAX为00402649
在这里插入图片描述
转到00402649,最终跳转到402C17。
在这里插入图片描述

  1. 7401E5A7的CALL EAX命令最终调用的是402C17地址处的函数。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值