【iOS逆向】theos安装、环境配置、和hook简单使用
安装theos
已安装过brew
1、安装ldid
data:image/s3,"s3://crabby-images/18ddb/18ddb213a95ff56a5fae6484243480363e91474d" alt=""
2、下载theos(直接下载可能不全)
data:image/s3,"s3://crabby-images/92731/927318d2f4afa8c73f52c85755fd7d4c849b1925" alt=""
通过gitclone指令下载
data:image/s3,"s3://crabby-images/b552a/b552a0f0d8762afc324488fbd93e7c07b37dda82" alt=""
recursive表示递归
$THEOS代表下载的路径
因为我在dumpdecrypted-master中执行的命令,所以theos存储在dumpdecrypted-master中,那么
使用的话,也是在这个文件夹中操作,所以最好放在一个系统文件夹中(比如usr)。我已转移到~(home)文件夹中
data:image/s3,"s3://crabby-images/8a83d/8a83dcfb59a22e6d6de80d267f22f537e31ab819" alt=""
配置PATH环境变量(方便在任意地方引用theos中的命令)
data:image/s3,"s3://crabby-images/b2892/b28920a40ebb3ff3045e4550889456151d79ef18" alt=""
在bash_profile中编辑
data:image/s3,"s3://crabby-images/83b14/83b14fafa1c0aba5ec5aa45ab47682a99ae78b0c" alt=""
进入编辑
data:image/s3,"s3://crabby-images/1ef3c/1ef3cc6f82db74101ad0ff40141f26e351bc56bb" alt=""
一般修改后执行一遍source命令使得环境变量生效
data:image/s3,"s3://crabby-images/f6490/f6490e46db7851e6ad34a50cc56558f78c22c7c4" alt=""
使用
切换到桌面
nic.pl列出创建类型的项目
data:image/s3,"s3://crabby-images/ce729/ce7295e2f07ec29f74e56057cc304f417954503a" alt=""
原正版包ID查看方法
data:image/s3,"s3://crabby-images/07013/07013984c7d943e856d6f8f5782080e8eb5f8175" alt=""
最后得到
data:image/s3,"s3://crabby-images/af632/af6326029917eaa09e94177e4033143a2f038152" alt=""
看端口
data:image/s3,"s3://crabby-images/cc6de/cc6de533d8380b8e700cfcab69be2addf68ca6ef" alt=""
data:image/s3,"s3://crabby-images/ebe70/ebe705440d80a6b8a27ae3f9e49fc623613cdd06" alt=""
添加iPad的地址和端口
data:image/s3,"s3://crabby-images/4e731/4e731440c0bea0c737f25f0a514bcca76695a031" alt=""
查找要hook的App功能的类名
data:image/s3,"s3://crabby-images/233b8/233b8f87382dbc9a5f0f295e9e0c51f6c790ce58" alt=""
通过DYLD_INSERT_LIBRARIES=dumpdecrypted.dylib脱壳得到
data:image/s3,"s3://crabby-images/90344/903444375b1cdc0a76306031d9c62c533ccf4828" alt=""
data:image/s3,"s3://crabby-images/23c56/23c56cdc42be5330db4bbfba57b2c776d90825cd" alt=""
去掉后缀名
再通过class-dump得到的头文件
data:image/s3,"s3://crabby-images/730c1/730c18fe47c8f540b2d2c52d829bd31b8e9df3a9" alt=""
data:image/s3,"s3://crabby-images/47728/477287f213df2bb8d958edc1cf9493058f044230" alt=""
文件夹拖入sublime通过command+p查找类名
查看要hook的方法
data:image/s3,"s3://crabby-images/1b803/1b80307389b3b52543fbe9753d90f67185307802" alt=""
实现hook方法
data:image/s3,"s3://crabby-images/9ccda/9ccda62e5b77b6ba018b3b1db5e190724537da2a" alt=""
在生成的文件夹中使用make命令编译
data:image/s3,"s3://crabby-images/daf49/daf49626caa3af0a608754d78014fe4a10f02d36" alt=""
如果报错
bogon:letweakting Lin$ make
Makefile:5: /opt/theos/makefiles/common.mk: No such file or directory
Makefile:10: /tweak.mk: No such file or directory
make: *** No rule to make target `/tweak.mk'. Stop.
则在Makefile中添加如下路径
data:image/s3,"s3://crabby-images/095ee/095ee8cb98e823530bf89fee61170d664c734157" alt=""
编译完成
data:image/s3,"s3://crabby-images/b2608/b26084f8d143561864a4ee6a33b56373d659bffe" alt=""
然后打包
注释掉theos源码theos/vendor/dm.pl/dm.pl文件中的
data:image/s3,"s3://crabby-images/83025/83025dbc180f6d2b0e6e5fd033523f3b1e334a7c" alt=""
修改theos/makefiles/package/deb.mk中第6行的lzma改为gzip
data:image/s3,"s3://crabby-images/d8b36/d8b36a6cbd40bb22334d60c563b53233d6c3b950" alt=""
重新make package
得到
data:image/s3,"s3://crabby-images/ac632/ac632940ed75fe2cdbe17b096c8237689fde9084" alt=""
如果在make成功之后还想make 发现报了Nothing to be done for `internal-library-compile’错误
那就把你刚才创建出来的obj删掉和packages删掉 , 然后显示隐藏文件, 你就会发现和obj同一个目录有一个.theos , 吧.theos里面的东西删掉就好了
data:image/s3,"s3://crabby-images/c164b/c164b7a86ee83aae023ded3dff55ff130664007e" alt=""
最后安装报错
data:image/s3,"s3://crabby-images/3c269/3c2690b67755aae7ff0000f2ae33d745309ce076" alt=""
需要作端口映射[【iOS逆向】usbmuxd的安装和使用 关联sh脚本]https://www.jianshu.com/p/05dec177702d
最后安装成功
data:image/s3,"s3://crabby-images/16f13/16f13b25f5c71affb4193798be5da95af35660f3" alt=""
iPad会自动重启。
再次打开已经没有XMSoundPatchImageView了
data:image/s3,"s3://crabby-images/dd111/dd1110be56ab631d70cf049f2b9df403c2c51852" alt=""