MachObfuscator全面解析:Apple平台Mach-O应用程序混淆技术指南

MachObfuscator是一种与编程语言无关的Mach-O应用程序混淆器(适用于Apple平台)。

当前状态

✅ -- 表示功能已完成, ❌ -- 表示功能是待办事项/正在进行中。

✅ Mach-O iOS

✅ Mach-O macOS

✅ iOS NIB(包括故事板)

⚠️ macOS NIB(包括故事板) -- 尚不支持绑定

❌ MOM(CoreData)

❌ Mach-O watchOS

❌ Mach-O tvOS

❌ 位码

❌自动代码重新签名(需要手动重新签名所有图片,请参阅resign.sh

概述

MachObfuscator是一个二进制符号混淆器。这是什么意思?有一些重要的术语:

1.混淆器 -- 一种使软件难以逆向的工具。

2.二进制混淆器 -- 一种混淆器,它在机器代码上运行,而不是在源代码上运行。

3.符号混淆器 -- 一种仅混淆符号名称的混淆器,不会改变程序控制流。

MachObfuscator 直接转换Mach-O文件中的符号。Mach-O格式主要用于Apple平台,作为可执行文件和库的机器代码容器。MachObfuscator不需要访问应用程序源代码以对其进行模糊处理。

类似地,IpaGuard是一款专注于iOS IPA文件混淆的工具,它提供代码混淆、资源文件混淆等功能,无需源码即可操作,支持多种开发平台,有效增加反编译难度。

演示

让我们看看MachObfuscator混淆SampleApp.app应用程序:

通过在MachOView中打开app的主要可执行文件可以看到结果。MachOView显示模糊的ObjC选择器:

和混淆的ObjC类名:

上面仅显示了样本更改。MachObfuscator更改了更多Mach-O部分。

用法细节 $ ./MachObfuscator usage: ./MachObfuscator [-qvdhtD] [-m mangler_key] APP_BUNDLE Obfuscates application APP_BUNDLE in-place. Options: -h, --help 帮助 -q, --quiet 安静模式 -v, --verbose 输出详细信息 -d, --debug 调试模式,输出更详细的信息 --dry-run 不保存模糊文件 --erase-methtype 擦除methType部分 -D, --machoview-doom MachOView在尝试打开二进制文件后崩溃(不适用于caesarMangler --swift-reflection 混淆了Swift反射部分(typeref和reflstr)。 --objc-blacklist-selector NAME[,NAME...] 不会混淆给定的选择器 --objc-blacklist-selector-regex REGEXP 不会混淆与给定正则表达式匹配的选择器 --preserve-symtab 不会删除SYMTAB字符串 --erase-section SEGMENT,SECTION SECTION擦除给定部分,例如:TEXT, swift5_reflstr --erase-source-file-names PREFIX 从二进制文件中擦除源文件路径。删除以给定前缀开头的路径,用常量字符串替换它们 --replace-cstring STRING 用给定的替换任意__cstring(谨慎使用)。匹配整个字符串, --replace-cstring-with STRING 如果需要,可以添加填充0。这些选项必须成对使用。 --skip-all-frameworks 不会混淆框架 --skip-framework framework 不会混淆给定的框架 --obfuscate-framework framework 框架模糊了给定的框架(白名单为--skip-all-frameworks) -m mangler_key, --mangler mangler_key 选择mangler来生成混淆的符号 Development options: --xx-no-analyze-dependencies 不分析依赖关系 Available manglers by mangler_key: caesar - ROT13所有objc符号和dyld信息 realWords - 用随机单词替换objc符号(支持dyld信息混淆)

简单化,MachObfuscator:

1.查找应用包中的所有可执行文件,

2.以递归方式搜索所有依赖库,这些库的依赖关系等等,

3.搜索应用包中的所有NIB文件,

4.区分可模糊文件(应用程序包中的文件)和不可模糊文件(应用程序包外部的文件),

5.从整个依赖图中收集Obj-C符号,导出尝试和导入列表,

6.创建符号白名单和符号黑名单(在不可混淆的文件中使用的符号),

7.使用选定的漫游器修改白名单符号,导出尝试和导入列表,

8.替换可混淆文件中的符号,

9.清除可选的部分,

10.一次保存所有文件。

MachObfuscator在Mach-O部分之后发生变化:

1.__TEXT, __objc_classname - mangles符号名称

2.__TEXT, __objc_methname - mangles符号名称

3...__TEXT, __objc_methtype- mangles符号名称或可选(使用--erase-methtype参数启用)用0s 填充整个部分

4.__TEXT, __swift3_typeref,__TEXT, __swift4_typeref,__TEXT, __swift5_typeref-用填充整段0小号

5.__TEXT, __swift3_reflstr,__TEXT, __swift4_reflstr, __TEXT, __swift5_reflstr-用填充整段0小号

6.LC_DYLD_INFO_ONLY - mangles导出尝试和绑定列表

7.LC_SYMTAB- 用0s 填充整个部分

8.__TEXT, __swift*是Swift的反射机制使用的部分。Mirror即使在清除这些部分之后,也可以返回不太详细的数据。LC_SYMTAB用于lldb。

MachObfuscator不会影响崩溃符号,因为是在编译期间生成的 -- 即在混淆之前。

相关推荐
TON_G-T12 分钟前
uniapp-降低主包体积-分包js
webpack·uni-app
专科3年的修炼12 分钟前
uni-app移动应用开发第三章
uni-app
LAM LAB13 分钟前
【Mac】修改改 command 和 alt 键位映射
macos
vx-bot55566624 分钟前
企业微信ipad协议的协议状态机与生命周期管理
ios·企业微信·ipad
ITKEY_36 分钟前
macOS通过命令行启动iOS模拟器
macos·ios
00后程序员张1 小时前
iPhone 无需越狱文件管理 使用Keymob查看导出文件
android·ios·小程序·https·uni-app·iphone·webview
OneCrab1 小时前
Iphone漏洞利用工具包 Coruna DarkSword
ios·cocoa·iphone
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于微信小程序的运动减肥管理系统设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
2501_915106321 小时前
不依赖 Mac 也能做 iOS 开发?跨设备开发流程
ide·vscode·macos·ios·个人开发·swift·敏捷流程
2501_916008891 小时前
Unity3D iOS 应用防篡改实战 资源校验、 IPA 二进制保护
android·ios·小程序·https·uni-app·iphone·webview