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

 

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

图片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

 

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

 

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

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

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

图片4

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • gzs

    @billvsme: 快来评论啊!

    评论: 写得不错哟

    2019-05-08 10:42:55          回复

  • billvsme

    评论: 快来评论啊!

    2015-05-07 10:08:36          回复