蜗牛iOS逆向

MonkeyDev + Xcode 14.x 使用过程中各种错误

2023-07-11  本文已影响0人  蜗牛iOS

MonkeyDev + Xcode 14.x 使用过程中各种错误解决

文章背景

在五月底,博主应机友们期望开发一款自适应/锁定 120Hz 的越狱插件,但尴尬的是手中无可越狱的高刷设备如 iPhone 13 Pro。

手中常用设备是 14 Pro 16.1.2 / XR 15.1,其中 XR 可多巴胺越狱,用于日常越狱插件开发;

而要实现的 iOS 高刷原理逆向分析,只有 13 Pro/14 Pro 具备,而手持的 14 Pro 不可越狱,那么怎么完成此次逆向分析 + 插件开发呢?最终博主采用了如下开发路线:

最终插件诞生了。

此处插入公众号文章链接

今天特将 Monkey Dev + Xcode 14.x 系列踩过的各种坑及解决方法,整理出来,分享给大家。

MonkeyDev 介绍

Monke Dev 套件是刘培庆圈内大家叫庆哥 AloneMonkey,在 iOSOpenDev 的基础上开发,于六年前 2017 年发布,当时主要支持 Xcode 8 以上,用于在 iOS 非越狱手机中能够进行第三方 App 逆向分析。

但在四年前庆哥已经停止维护更新了,所以最新版本 Xcode 14 可能会遇到各种错误,依次讲解如下。

理论上,本文章遇到的各类错误适用于所有 Xcode12 及其以上。

各类错误

安装报错

错误在于 Xcode 新版本中模板的路径发生改变,从而导致报错。可按照如下操作解决:

报错 libstdc++

在新建 MonkeyDev 项目后,运行 MonkeyDev 项目时,会报错 libstdc++ 错误,如下图所示

git clone https://github.com/devdawei/libstdc-.git
cd <u>libstdc-
</u><u>sudo</u> bash <u>./install-xcode_11+.sh</u> 

报错执行文件路径为文件夹

报错 EXC_BAD_ACCESS

可以观察到这个报错是在 perform_rebinding_with 也即 fishhook 导致的

按照如下路径进行解决:

报错 Unable to install xxx

这个是最难解决的,报错的现象是,首次安装成功,注入 Dylib 也成功,但是再次编译就无法安装运行了。

点进 Detail 进去的错误信息,搜索网上的各种方法,都试过了,都没用。

rm -rf "${TARGET_APP_PATH}/_CodeSignature" || true
rm -rf "${TARGET_APP_PATH}/SC_Info" || true

报错 Dylib 签名错误

这个是因为 monkeytestdylib 的Build Settings中的签名和主项目文档不一致导致。按照如下图解决:

编译后,Hook 代码未生效

在编译成功后,可能会发现 Hook 代码没有生效,MonkeyDev 的工作原理是,在使用 Logos 语法时,会将 xm 文件转换为 m 文件。

所以编写后,要 command+s 保存 xm 文件。

如果发现 Hook 代码没有生效,就观察下.m 文件是否已有相应 Hook 代码

文章结尾

MonkeyDev 在 iOS 逆向分析分析中提供了便利功能,包含了代码注入、反反调试、Cycript、Reveal 等,最让开发者舒服的是原生 Xcode 编译 + 调试体验,感谢庆哥在越狱圈子的贡献。

上一篇 下一篇

猜你喜欢

热点阅读