准备工作
找出程序的可执行文件路径
- root#
ps aux | grep Snapchat
列出所有的 Frameworks
- xx.app root#
ls Frameworks
把所需要解密的库,复制出来
scp -P 2222 -r root@localhost:/var/....xx.app/Frameworks/xx
scp -P root@10.0.0.3:/var/....xx.app/Frameworks/xx
获取可执行文件的头部信息
otool -hf xxx(可执行文件)
获取64位的加密信息(arm64)
-
otool -arch arm64 -l 可执行文件 | grep crypt
LLDB 附加
获取解密的目标文件加载模块的基地址
im list -o -f 可执行文件
获取解密后的二进制数据
-
memory read --force --outfile ~/Desktop/dumpoutput --binary --count cryptsize cryptoff+基地址
- cryptsize来自加密信息,cryptoff 也是来自加密信息
~/Desktop/dumpoutput 是保存到本地计算机的目标可执行文件,这个文件包含的是解密后的数据
修复文件
因为 dump 出来的文件都没有 Mach-O 文件头,所以要先把 dump 出来的数据写会原来加密的文件,以替换原来加密的部分.
dd seek=20086784 bs=1 conv=notrunc if=/Users/wyp/Desktop/dumpoutput of=./可执行文件名
20086784是20070400+16384的计算结果.20070400是之前获取的 arm64架构的偏移值 offset,16384 是加密数据的 crypoff, 二者相加,得到了写入加密数据在文件中的偏移值
替换之后,使用 lipo 从 FAT 文件中提取 arm64 架构的文件,然后将 arm64_tmp 拖到 MachOView 中,修改 cryptid 的值为00000000,然后就完成了 framework 的解密.
lipo 可执行文件 -thin arm64 -output arm64_tmp
查看64位的加密信息
完成
部分 framework, 通过 image li 查不到基地址,解密的方式待续!