首页 > 其他 > 详细

反调试之Fake F8

时间:2020-07-06 14:47:10      阅读:44      评论:0      收藏:0      [点我收藏+]

1.F7&F8

两者在执行普通指令是没有什么不同的。F7和F8主要的不同在于对call指令的调用

  F8:把整条CALL指令当成一条指令来执行,当执行完call这条指令后,继续执行当前指令的下一条指令

  F7:会进到CALL指令后的地址逐个执行指令

2.调试器如何实现

(1)断点

断点:让程序执行到指定位置。

DTDebug中如何使用:选中一行指令按F2,再运行程序的话就能让程序执行到指定位置。

技术分享图片

 

设置了断点的位置,当启动时程序会执行到该位置并停止,这个同指令INT 3 。都是表示断点。

断点的本质:

  • 指令INT 3:当CPU执行到指令INT 3时,就会停到调试器。——INT 3对应的值是 CD 03;且16进制的CC对应的值也是INT 3
    • 当我们按F7的时候,程序会一行一行的执行。因为把EFL寄存器里面有个标志位(TF位),如果把这个TF位设置1,当前CPU就会进入单步执行模式。
    • 当按F8的时候,直接在当前CALL指令下一条指令后面加一个CC。

(2)F8反调试:

  让F8下一步指令断不下来

步骤:

  技术分享图片

 

 当使用F8执行的时候,执行到call的那条指令时,当前call指令的下一条指令0119ECF5已经被压到的栈中,此时执行当前(0119 ED17)指令将栈指针修改成一个不存在的地址即可实现反调试

  不过这种反调试方法对F7无效

反调试之Fake F8

原文:https://www.cnblogs.com/codexlx/p/13252201.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!