OllyDbg 使用笔记 (十九)

OllyDbg 使用笔记 (十九)


参考

书:《加密与解密》

视频:小甲鱼 解密系列 视频


反调试


先看看这四个程序。(下载地址:http://pan.baidu.com/s/1pJCzABp)

它们自己运行时都没有问题,都显示被注册信息 “You really did it! Congratz it",但是一到OD中运行就会出现未注册或者报错。

这四个程序都对OD进行了反调试。


它们都用了IsDebuggerPresent这个API函数来判断是否程序被调试器调用。


可以先看看ReverseMe.A程序,正常运行时会出现“You really did it! Congratz it"窗口,但是OD运行会出现”Keyfile is not valid.Sorry.“窗口。OD加载程序,F8单步,可以发现call 004010FB产生未注册窗口。

图片1

OllyDbg 使用笔记 (十九)_第1张图片


在call 004010FB下断点,程序运行程序,按F7进入call 004010FB,查看004010FB的代码:

图片2

OllyDbg 使用笔记 (十九)_第2张图片



函数通过IsDebuggerPresent这个API判断是否使用OD调式程序,如果是eax = 1,je   short 004010E2  实现跳转,产生”Keyfile is not valid.Sorry.“窗口。可以直接把je   short 004010E2 改成nop 就可以去除反调试。其它三个ReverseMe都大同小异。



再来看看Debugger Detected这个程序(下载地址:http://pan.baidu.com/s/1WuD4),如果不用英文的OD打开它,按下Verify会出现”Debugger NOT detected!!“窗口;如果用英文的OD打开它会产生一个ERROR窗口写“着Your debugger is detected!!!”。

用英文OD打开它,可以看到程序开头就是一个DialogBoxParamA函数创建 模态对话框。

图片3

OllyDbg 使用笔记 (十九)_第3张图片


其中0040108C是这个模态对话框的过程函数。


在0040108C下断点,按F9运行到0040108C处,按F8单步调试。

可以发现,当第二次运行0040108C时,在 call    004011CB 会产生ERROR窗口。在call    004011CB下断点,重新运行,跟进。

可以发现call    004011CB其实是查看当前系统所有的进程,搜索所有进程中的是否存在叫“OLLYDBG.EXE”的进程,如果有就产生ERROR窗口。

图片4

OllyDbg 使用笔记 (十九)_第4张图片






















你可能感兴趣的:(OllyDbg,反汇编)