IDA F5 增强插件: I Have a Dream (二)

简介: IDA F5 增强插件: I Have a Dream (二)

一、目标



Rolf Rolles大佬曾经说过,一图胜千言93.png

一堆丑陋的 While 是没有加立白的效果,干净漂亮的 if 是加了立白的效果。


二、步骤

控制流平坦化示意图95.png

上图是个漂亮的if else 结构。96.png

先给每个块分配一个label标签

97.png

然后增加一个块变量,来指示应该执行哪个块。

97.png


每个块跑完之后不直接到自己的后继块,而是到主分发器块,这样漂亮的if else结构就由丑陋的switch语句代替了。


反控制流平坦化


  • 先找到主分发器
  • 再找到 块变量
  • 后继块只有一个块的,把块变量删除,然后直接goto到后继块
  • 后继块有两个块的,把块变量删除之后,增加比较操作。恢复 if else结构


分析下D810是怎么搞的


plugins\d810\log.ini 中

[logger_D810Unflat]
level=DEBUG
handlers=defaultFileHandler
qualname=D810.unflat
propagate=0
[logger_D810Tracker]
level=DEBUG
handlers=defaultFileHandler
qualname=D810.tracker
propagate=0


打开这两处调试信息的打印。


然后F5一下 anel.bin,的 sub_1000CF20 函数


之后,在日志文件里面就会清晰的打印出,unflat过程中的日志信息在  plugins\d810_logs\d810.log


需要重点分析的是 plugins\d810\tracker.py 和 plugins\d810\optimizers\flow\flattening\generic.py 文件。


generic.py 文件中的  GenericDispatcherUnflatteningRule.remove_flattening 函数做了块的乾坤大挪移的动作。


三、总结


我的梦想就是 F5一下,啥ollvm、Tigress混淆都是渣渣。


D810给我们提供了一个非常经典的样例,仔细分析分析它。你的F5从此不一样了。

98.png


摔倒了爬起来,赶快走,别心疼摔倒的那个坑


TIP: 本文的目的只有一个就是学习更多的逆向技巧和思路,如果有人利用本文技术去进行非法商业获取利益带来的法律责任都是操作者自己承担,和本文以及作者没关系,本文涉及到的代码项目可以去 奋飞的朋友们 知识星球自取,欢迎加入知识星球一起学习探讨技术。有问题可以加我wx: fenfei331 讨论下。


关注微信公众号: 奋飞安全,最新技术干货实时推送


相关文章
|
Java Linux 开发工具
Linux安装JDK1.8
Linux安装JDK1.8
473 0
|
安全 Linux 网络安全
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息
nmap 是一款强大的开源网络扫描工具,能检测目标的开放端口、服务类型和操作系统等信息。本文分三部分介绍 nmap:基本原理、使用方法及技巧、实际应用及案例分析。通过学习 nmap,您可以更好地了解网络拓扑和安全状况,提升网络安全管理和渗透测试能力。
805 5
|
安全 Linux 网络安全
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
【工具使用】几款优秀的SSH连接客户端软件工具推荐FinalShell、Xshell、MobaXterm、OpenSSH、PUTTY、Terminus、mRemoteNG、Terminals等
130279 0
|
编译器 C语言 C++
VSCode安装配置C语言(保姆级教程)
VSCode安装配置C语言(保姆级教程)
1156 4
|
数据采集 算法 搜索推荐
R语言营销数据分析:使用R进行客户分群的实践探索
【9月更文挑战第1天】R语言以其强大的数据处理和统计分析能力,在金融数据分析、营销数据分析等多个领域发挥着重要作用。通过R语言进行客户分群,企业可以更好地理解客户需求,制定精准的营销策略,提升市场竞争力和客户满意度。未来,随着大数据和人工智能技术的不断发展,R语言在营销数据分析中的应用将更加广泛和深入。
|
Dart IDE 开发工具
鸿蒙Flutter实战:09-现有Flutter项目支持鸿蒙
本文介绍了将现有Flutter项目适配鸿蒙系统的步骤。首先,根据[鸿蒙Flutter适配指南]搭建开发环境,并使用fvm管理多版本SDK。项目采用模块化设计,包括apps、common、components、modules和plugins等目录,分别对应不同功能模块。重点在于在apps目录下创建新的鸿蒙项目,逐步添加依赖并解决版本兼容性问题。最后,通过配置pubspec.yaml文件和特定插件的鸿蒙化适配,完成项目的编译与运行测试。
986 0
|
自然语言处理 索引
ES中如何对text字段进行精确匹配
ES中如何对text字段进行精确匹配
1490 0
vscode中可能遇到的一些问题
vscode中可能遇到的一些问题
615 1
|
缓存 安全 程序员
IDA F5 增强插件,还我源代码(一)
IDA F5 增强插件,还我源代码(一)
IDA F5 增强插件,还我源代码(一)
|
存储
解压cpio文件
解压cpio文件 cpio -idmv < filename.cpio 同样可以解压img文件:cpio -idmv < filename.
1525 0