一、动静结合逆向程序举例

1.无明显main函数

有时,ida左边的分析栏中会遇到无明显main函数入口的情况,此时查找编译器入口(程序的起始点是编译器添加的入口,编译器初始化数据后,调用main函数,如果没有main函数,则只能从编译器入口着手)。
main函数传参有三个参数,所以通过查找3个push,1个call,定位编译器入口,从而定位main函数。
PC逆向入门
进入main函数后,我们发现有一个strcmp一个函数比较,可以考虑通过动态调试定位参数值
PC逆向入门

2.通过动态调试Ollydbg定位参数值

OD打开后,正常显示call,jmp入口。
如无明显main函数,jmp处回车跟进,找3个push,1个call。
PC逆向入门
PC逆向入门
回车跟进call,同时让OD数据窗口跟随内存地址,如下所示:
PC逆向入门
F2在相应位置下断点,然后F8单步运行程序,数据窗口flag
PC逆向入门

二、输入***程序逆向举例

题目如下
PC逆向入门
在OD中分析,根据报错提示查找字符串
PC逆向入门
PC逆向入门
回车进入Serial is error! 对应代码块
PC逆向入门
修改je 条件判断代码块,改为不要判断,用nop填充。选中代码块,右键汇编
PC逆向入门
PC逆向入门
执行程序
PC逆向入门

右键,保存到可执行文件

PC逆向入门

相关文章:

  • 2021-08-30
  • 2021-06-06
  • 2021-08-31
  • 2022-12-23
  • 2021-06-05
  • 2022-12-23
  • 2021-08-28
  • 2021-05-28
猜你喜欢
  • 2022-12-23
  • 2021-04-08
  • 2022-01-10
  • 2021-05-23
  • 2021-05-08
  • 2022-01-08
  • 2021-10-29
相关资源
相似解决方案