我们日常开发提交给Appstore发布的App,都经过官方保护而加密,这样可以保证机器上跑的应用是苹果审核过的,也可以管理软件授权。经过App Store加密的应用,我们无法通过Hopper等反编译静态分析,也无法Class-Dump,在逆向分析过程中需要对加密的二进制文件进行解密才可以进行静态分析,这一过程就是大家熟知的砸壳(脱壳)
一、Clutch
由KJCracks开发的一款开源砸壳工具。
具体操作
1、使用Clutch,下载最新的release版本,可得到一个名为Clutch-2.0.4
的胖二进制文件。
2、通过usb登录越狱设备。
3、通过命令scp -P 12345 Clutch-2.0.4 root@localhost:/usr/bin
将其拷贝到越狱设备的指定目录下。
可通过mv Clutch-2.0.4 Clutch
对其重命名。
4、查看Clutch
的可执行权限。没有的话就chmod +x Clutch
添加权限即可。
5、进入到越狱设备的命令行操作界面。通过Clutch
命令可查看相关命令帮助信息。
1 | Dyoung5s:~ root# pwd |
6、Clutch -i
显示可砸壳的应用列表。
1 | Dyoung5s:~ root# Clutch -i |
7、Clutch -d 4
选择要砸壳的应用,并进行砸壳,成功后有如下提示。将其拷贝出来即可。我们也可以通过otool -l
查看其cryptid
字段以验证是否砸壳成功。
二、dumpdecrypted
通过建立一个名为dumpdecrypted.dylib的动态库,插入目标应用实现脱壳。
1、下载dumpdecrypted,并通过make
命令编译生成dylib
库。
2、通过命令scp -P 12345 dumpdecrypted.dylib root@localhost:~/
将动态库拷贝越狱设备的指定目录。
3、通过ps -A
查看当前进程,并通过如下命令将其动态库插入到指定进程中。即可生成对应进程应用的MachO
文件。
1 | //后面加上的进程路径。 |
三、frida-ios-dump
安装
1、下载pip
1 | sudo easy_install pip |
2、通过pip
下载frida_tools
1 | sudo -H pip install frida_tools |
3、直接clone
frida-ios-dump到本地目录,进入目录可发现dump.py
脚本文件。
4、修改dump.py
文件中的如下信息,确保与越狱设备信息匹配。
5、在越狱设备中添加https://build.frida.re
源,并且安装Frida
插件.
dump应用
将脱壳应用在设备上置于运行状态。进入脚本所在文件夹,通过./dump.py 微信
便可成功脱壳应用。成功后会在脚本文件所在文件夹中生成ipa包。
以上dump时的操作可写成脚本,将frida-ios-dump
文件夹放置sh脚本文件的同级目录中。编写脚本,并配置环境变量即可。
1 | //脚本内容: |
遇到的一些坑:
1、No module named xxx
。 通过pip install --user xxx
下载即可。
2、from scp import xxx
,同上执行pip install --user xxx
即可。
3、生成ipa,存放到脚本文件所在文件夹时没有写的权限。可直接对文件夹执行sudo chmod -R 777 文件夹路径
即可。
四、lldb手动dump
准备
1、在手机中配置好debugserver
。
2、通过以下命令导出需要dump应用的可执行文件到当前路径。xxxx代表应用进程路径。
1 | scp -P 12345 root@localhost:xxxx ./ |
3、查看瘦身后的可执行文件的加密信息。并记录。
1 | ● otool -l Aweme_arm64 | grep cry |
分析:cryptoff
:指加密文件的头所对应的偏移。这个数字之前代表着可执行文件的header。cryptsize
: 加密的数据长度,我们需要把这段时间拷贝出来。
实操
1、开启debugserver
服务,依附到我们想要dump应用的进程中。
1 | debugserver *:9393 -a Aweme |
2、电脑进入lldb
调试环境,连接到对应的debugserver
端口。
1 | process connect [connect://localhost:9393](connect://localhost:9393) |
3、通过image list
指令拿到可执行文件的头地址,加上之前的cryptoff
得到需要拷贝数据的起始地址。
4、按字节读取内存中的可执行文件,并拷贝到电脑。(耗时动作)
1 | //--force:按字节读取。 |
5、将二进制文件包替换之前拷贝出来的可执行文件中的对应部分,得到一个新的可执行文件。
1 | //dd:用指定大小的文件写到另一个文件当中。 |
6、通过otool -l
查看新的可执行文件,得知cryptid
仍为1,这里是因为我们并没有对header
文件作修改,所以字段的值仍保持之前加密的键值。但是可执行文件的内容却被我们解密了的。可以通过class-dump
验证。
7、通过Mach0View
修改cryptid
的值为0。如果不修改class-dump
会不成功。因为这个工具首先会拿到header
获取cryptid
的值,如果是已加密的话就会放弃后面的dump工作了。
8、通过class-dump -H Aweme_arm64 -o ./AwemeHeaders
能导出应用的头文件,便可证明lldb手动脱壳成功。
补充
frida_tools的一些使用
1、配置端口映射。
通过frida-ps
列出当前应用进程。
通过usb连接好手机后,通过frida-ps -U
列出usb设备的应用进程。
2、通过frida -U 微信
附加进程到微信。
3、执行ObjC
可拿到附加进程应用的所有Object-C
对象。
插入自定义动态库到指定应用
通过这样的操作,进程没有被污染,在以后的每次执行时候不会执行我们所插入的动态库的方法。这里只相当于一次性插入。上文的dumpdecrypted便是用到了这样的原理。
1、使用Xcode
生成framework
文件。通过以下命令拷贝到越狱设备中。
1 | scp -r -P 12345 DyInsert.framework/ root@localhost:~/ |
2、通过以下命令将动态库插入到指定进程即可。
1 | DYLD_INSERT_LIBRARIES=DyInsert.framework/DyInsert /var/mobile/Containers/Bundle/Application/4560ADA4-9AE4-4E9D-BE84-ABF666B12A7A/WeChat.app/WeChat |