PC逆向入门

PC逆向入门

  • 一、动静结合逆向程序举例
    • 1.无明显main函数
    • 2.通过动态调试Ollydbg定位参数值
  • 二、输入序列号程序逆向举例

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

1.无明显main函数

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

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

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

二、输入序列号程序逆向举例

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

右键,保存到可执行文件

PC逆向入门_第14张图片

你可能感兴趣的:(ctf)