MonkeyDev是一位大神基于iOSOpenDev重新弄的,是一款非越狱插件开发集成神器!大神就是大神!
data:image/s3,"s3://crabby-images/253b7/253b76e5f1467c81f2ed2ee1b3956cf828750fb6" alt=""
一.安装MonkeyDev
1.环境要求
(1).安装最新的theos
sudo git clone --recursive https://github.com/theos/theos.git /opt/theos
(2).安装ldid(如安装theos过程安装了ldid,跳过)
brew install ldid
(3).配置免密码登录越狱设备(如果没有越狱设备,跳过)
ssh-keygen -t rsa -P ''
ssh-copy-id -i /Users/username/.ssh/id_rsa root@ip
或者安装sshpass自己设置密码:
brew install https://raw.githubusercontent.com/kadwanev/bigboybrew/master/Library/Formula/sshpass.rb
2.MonkeyDev的安装指令
(1). 命令选择指定的Xcode进行安装
sudo xcode-select -s /Applications/Xcode-beta.app
默认安装的Xcode为:
xcode-select -p
执行安装命令:
sudo /bin/sh -c "$(curl -fsSL https://raw.githubusercontent.com/AloneMonkey/MonkeyDev/master/bin/md-install)"
MonkeyDev卸载
sudo /bin/sh -c "$(curl -fsSL https://raw.githubusercontent.com/AloneMonkey/MonkeyDev/master/bin/md-uninstall)"
MonkeyDev更新
如果没有发布特殊说明,使用如下命令更新即可:
sudo /bin/sh -c "$(curl -fsSL https://raw.githubusercontent.com/AloneMonkey/MonkeyDev/master/bin/md-update)"
二.MonkeyDev的使用
1.创建项目
data:image/s3,"s3://crabby-images/43855/43855bbc62e5d836d5c12009f04200d4872fd984" alt=""
2.分析目录结构
data:image/s3,"s3://crabby-images/f3e8f/f3e8fce63f7611e6930fea5fe9062c2bd343cf2d" alt=""
3.拖入编译(如果无越狱手机请参考无需越狱手机下载越狱版本IPA的方法)
4.运行,如果报以下这样的错误:
data:image/s3,"s3://crabby-images/be71a/be71a5f0289f0da11b43b26556839f02e5c3df34" alt=""
解决方案:
data:image/s3,"s3://crabby-images/2a789/2a78936bc9549e68eb94462a50433906cc67796d" alt=""
三.动态库调试和修改
假如你想修改一个APP的内容显示,我们可以这么做?
1.使用class-dump 和Hopper实现简单反编译看到ipa文件的头文件,以我们自己的项目为例:
data:image/s3,"s3://crabby-images/b0a01/b0a011342f744266f5f61f2d0857429dfe5b874c" alt=""
2.找到HomePageViewControlle的头文件,属性City代表城市
data:image/s3,"s3://crabby-images/d2d7b/d2d7b359586e66c4235f086cccd20effcb227eeb" alt=""
3.在TestAppDylib.m中写入代码
CHDeclareClass(HomePageViewController); // declare class
CHOptimizedMethod(0, self, NSString *, HomePageViewController, city) // hook method (with no arguments and no return value)
{
// write code here ...
return @"湖南"; //随意改数
}
CHConstructor // code block that runs immediately upon load
{
@autoreleasepool
{
CHLoadLateClass(HomePageViewController);
CHHook(0, HomePageViewController,city);
}
}
不让使用runtime库,修改如图位置即可,改为NO.
data:image/s3,"s3://crabby-images/3a2ad/3a2ad44c99f548939d96559a57fd48e427127b81" alt=""
最后修改后的效果图:
data:image/s3,"s3://crabby-images/83534/835341b6fc5a1e313a096a12c364931357419a8e" alt=""
注:虽然知道项目的头文件,有很大的局限性,我们需要经过猜测找到要修改的控制器和变量名。
网友评论