data:image/s3,"s3://crabby-images/7aed2/7aed2c1dd2fa1a1741bf8d3e2f4878d533c3fdd3" alt=""
目录
一,加壳
二,脱壳
三,工具
四,验证
一,加壳
1,介绍
-
App Store会对
ipa
包中的可执行文件进行加壳操作 -
加壳就是利用特殊的算法,对可执行文件进行加密,以达到保护程序代码的目的
2,加壳前后
- 加壳前:可执行文件能够直接在内存中运行
data:image/s3,"s3://crabby-images/1afa9/1afa9cb23509ccce5d1f2d75a3120339185fd4af" alt=""
- 加壳后:壳程序会一同被加载进内存,壳程序会对可执行文件进行解密,这样可执行文件就能够运行了
data:image/s3,"s3://crabby-images/72282/72282803c6d6f4c253ad4d5dda4beb3c3c7e4355" alt=""
3,加壳的可执行文件是无法反编译的
- 从iPhone上导出喜马拉雅的可执行文件
data:image/s3,"s3://crabby-images/1f3c9/1f3c9ba7644d6fc6eda0f3b54069d32985594dda" alt=""
-
class-dump
:只导出一个无效.h
文件
data:image/s3,"s3://crabby-images/8a72b/8a72b5dd82f0125593a74b2c5b9a962a9033ca4b" alt=""
-
Hopper
:看不到类名、方法名等信息
data:image/s3,"s3://crabby-images/7c9e2/7c9e27e0ca3cf2806b1eb72d5e48eebce560b9c9" alt=""
二,脱壳
1,介绍
- 脱壳就是将壳程序去掉,并将已加密的可执行文件进行解密
2,方法
- 硬脱壳:直接执行解密算法(常用方法)
data:image/s3,"s3://crabby-images/82717/8271712fb6d1f446e2a3d74e24baf18225ae0648" alt=""
- 动态脱壳:将壳程序加载到内存中,壳程序会对可执行文件进行解密,然后导出可执行文件即可
data:image/s3,"s3://crabby-images/bf98e/bf98ec338377d2ca17a676df403fa0431253db0f" alt=""
三,工具
1,用Clutch
脱壳(下载地址:https://github.com/KJCracks/Clutch/releases)
- 下载并修改名称
data:image/s3,"s3://crabby-images/9114e/9114e7147703b42291070c0e2a4e7507678b18c0" alt=""
- 将
Clutch
拷贝到iPhone的/usr/bin
目录下
data:image/s3,"s3://crabby-images/8a29f/8a29fed2b2f3690f03661bd37eab8d4be4552e32" alt=""
- 赋予
Clutch
权限:chmod +x /usr/bin/Clutch
data:image/s3,"s3://crabby-images/20eaf/20eaf90bbca4598c8d3342e5f92d016507d9832e" alt=""
- 查看iPhone上已安装的APP:
Clutch -i
data:image/s3,"s3://crabby-images/6dcef/6dcefe5b9f4794c0a89439e2c577575e2b2e8dea" alt=""
- 开始脱壳:
Clutch -d [APP序号]
data:image/s3,"s3://crabby-images/07512/075123362319a010a82b5f20c156e05bd57af40b" alt=""
data:image/s3,"s3://crabby-images/8c4f5/8c4f52ada211c4dd00e1a64987069f46529f1dff" alt=""
- 脱壳成功后会生成一个新的
ipa
包
data:image/s3,"s3://crabby-images/b4490/b44900d44c614112de8fce3ce5a0e9a21dda1589" alt=""
2,用dumpdecrypted
脱壳(下载地址:https://github.com/stefanesser/dumpdecrypted)
- 下载并执行
make
命令,生成dumpdecrypted.dylib
动态库
data:image/s3,"s3://crabby-images/db2a1/db2a1fd9a9bf5a73d85fa0a2708621b27fba1a39" alt=""
- 将动态库拷贝到iPhone的
/var/root
目录下
data:image/s3,"s3://crabby-images/bd53a/bd53a9ed7562880c1c5be5bd77cafb91b27d7e76" alt=""
- 查看可执行文件路径:先运行APP,然后执行
ps -A
命令
data:image/s3,"s3://crabby-images/11f73/11f736fcb3882f34c01181c3518f8b1ce94930a7" alt=""
- 开始脱壳:
DYLD_INSERT_LIBRARIES=dumpdecrypted.dylib [可执行文件路径]
data:image/s3,"s3://crabby-images/b7d91/b7d9145f575da50119a630d3f5e1415b591459c2" alt=""
data:image/s3,"s3://crabby-images/577ce/577ce960e7845a120fc29d115c53783b2d86d1f2" alt=""
- 脱壳成功后会生成一个新的可执行文件
data:image/s3,"s3://crabby-images/739e5/739e52728b9f18e7ea6065b81447055704356a94" alt=""
3,用frida-ios-dump
脱壳
- 在iPhone上通过
Cydia
安装frida
插件(软件源:https://build.frida.re)
data:image/s3,"s3://crabby-images/59065/5906565293f72ebb528b86c1a49e05b845828986" alt=""
- 在Mac上配置
frida
环境:sudo pip install frida
data:image/s3,"s3://crabby-images/00ef6/00ef60ebe7c8b7ffb3ca129fa2a152518acaea40" alt=""
- 下载
frida-ios-dump
工具:git clone https://github.com/AloneMonkey/frida-ios-dump.git
data:image/s3,"s3://crabby-images/a624b/a624b1bc444889dff04b25d69acc69986da10d2e" alt=""
- 把
dump.py
文件中的端口号改为10010(跟登录iPhone所用端口号保持一致即可)
data:image/s3,"s3://crabby-images/ac564/ac564103d698fc1147b1e6003d74e40754bfb6e5" alt=""
- 查询APP的
bundleId
:./dump.py -l
data:image/s3,"s3://crabby-images/e6d60/e6d604977b82cc42d4a765b7772b833ba810384b" alt=""
- 先启动APP,然后开始脱壳:
./dump.py bundleId
data:image/s3,"s3://crabby-images/96c03/96c03717abd6bf7f2724b6c095684883ccc5cef6" alt=""
- 脱壳成功后会生成一个新的
ipa
包
data:image/s3,"s3://crabby-images/c3629/c3629f0d33effef115369770626398b58265401b" alt=""
4,比较
-
Clutch
:很多APP都会失败 -
dumpdecrypted
:只能对可执行文件进行脱壳,对于动态库不太好处理,有些APP会将代码封装成动态库 -
frida-ios-dump
:能处理动态库且成功率高(推荐使用)
data:image/s3,"s3://crabby-images/d5095/d5095874eceec87a71cde51802ef1a29240e1670" alt=""
四,验证
1,查看是否已脱壳
MachOView
data:image/s3,"s3://crabby-images/f0141/f01414bcbb0c07ac23243ee6d44014b07de65eb0" alt=""
data:image/s3,"s3://crabby-images/54a65/54a65b0f3f4ded242a6bdf4e8a7611d55f44264e" alt=""
otool
data:image/s3,"s3://crabby-images/c4464/c44646f517f79a5b8a1c782e38ce603b5b27fda3" alt=""
data:image/s3,"s3://crabby-images/bf73e/bf73ed59b1c8a01019a21743f0eb1fb95beaed13" alt=""
2,脱壳的可执行文件才能进行反编译
class-dump
data:image/s3,"s3://crabby-images/361ad/361ad6f63904b1ea4966fdf826c799659be8719a" alt=""
Hopper
data:image/s3,"s3://crabby-images/a271c/a271c570f29e807ccc4cc254429c6915b2cbb8f6" alt=""
网友评论