
2020-11-21(线性扫描反汇编算法和递归下降扫描反汇编算法)
发布日期:2021-05-07 12:06:12
浏览次数:18
分类:原创文章
本文共 653 字,大约阅读时间需要 2 分钟。
push ebp
jmp addr1
db 0xE8
addr1:
mov abp,esp
sub esp,0x100
根据线性扫描反汇编算法,当反汇编器解析完jmp addr1指令后,会接着从下一个0xE8开始进行解析,而0xE8为call指令的起始字节,就会导致反汇编器认为从0xE8开始的5个字节为一条call 指令,从而让后续的指令全部被错误解析
而对于以IDA Pro为代表的递归下降反汇编器,由于递归下降反汇编算法在遇到无条件跳转时,会转向跳转的目标地址递归地继续解析指令,就会导致插入的0xE8字节直接被跳过。然而,递归下降反汇编器尽管部分地模拟了程序执行的控制流过程,但它并不是真正运行,所以不能获取到所有的信息
例如:
push ebp
jz addr1
jnz addr1
db 0xE8
addr1:
mov abp,esp
sub esp,0x100
即将一条无条件跳转语句改为两条成功条件相反的条件跳转语句。由于递归下降反汇编算法不能获取到程序运行中的上下文信息,遇到条件跳转语句时,它会递归地将跳转的分支与不跳转的分支都进行反汇编。显然,在反汇编完jnz后,它不跳转的分支就是下一地址,从而使0xE8开头的“指令”被解析
实际操作时,往往打乱顺序,即“乱序”,从而达到类似控制流混淆的效果,例如:
push ebp
jz addr1
jnz addr1
db 0xE8
addr3:
sub esp,0x100
…………
addr2:
mov abp,esp
jmp addr3
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年04月10日 14时12分23秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
11.2.6 时间值的小数秒
2021-05-08
Redis源码分析(七)--- zipmap压缩图
2021-05-08
【MySQL】(九)触发器
2021-05-08
Oracle 11G环境配置
2021-05-08
【Python】(十二)IO 文件处理
2021-05-08
【Oozie】(三)Oozie 使用实战教学,带你快速上手!
2021-05-08
师兄面试遇到这条 SQL 数据分析题,差点含泪而归!
2021-05-08
C语言的数值溢出问题(上)
2021-05-08
8051单片机(STC89C52)以定时器中断模式实现两倒计时器异步计时
2021-05-08
vue项目通过vue.config.js配置文件进行proxy反向代理跨域
2021-05-08
android:使用audiotrack 类播放wav文件
2021-05-08
聊聊我的五一小假期
2021-05-08
数据库三个级别封锁协议
2021-05-08
ACM/NCPC2016 C Card Hand Sorting(upc 3028)
2021-05-08
ubuntu学习笔记-常用文件、命令以及作用(hosts、vim、ssh)
2021-05-08
SLAM学习笔记-求解视觉SLAM问题
2021-05-08
普歌-允异团队-HashMap面试题
2021-05-08
还在一个一个手动安装虚拟机吗?Cobbler自动部署装机一键最小化安装打把游戏就好了
2021-05-08
程序员应该知道的97件事
2021-05-08
create-react-app路由的实现原理
2021-05-08