您的位置:首页 > 移动开发 > IOS开发

IOS逆向--iOSOpenDev进行开发tweak

2017-09-11 13:11 369 查看
初来乍到研究越狱开发,昨天中午开始上网搜索越狱环境搭建,后来查到iosOpenDev软件,是个很方便的编写插件,而且可以直接用Xcode创建的工具,便开始着手学习如何去安装
集合了网上的方法后,我安装的时候发现:
1.作者最后更新的时间是四个月前,而且并未适配Xcode 6之后的版本,所以在当前OS X 10.11.1 和Xcode 7 下造成了很多问题
尤其是大量的安装失败却得不到解答方法,很是让我懊恼
2.同时需要适配的安装工具也已经严重过期,比如theos,ldid等工具
所以根据自己的摸索,附上一篇如何安装iosOpenDev的流程:

注意:请尽量尝试在翻墙后再进行安装,有一些网址也许会被国内网络拒绝访问

1.首先安装MacPorts软件,从官网根据mac本身的版本下载
下载后安装,进度条在安装时会停止一段时间,耐心等待
2.安装完MacPorts后打开终端
输入 sudo port -v self update 更新MacPorts到最新版本,继续耐心等待
3.更新完MacPorts后安装DPKG文件,在终端输入sudo port -f install dpkg
该文件用于打包.deb文件,用时也比较长
上面三部需要耗费挺长时间,网速慢的时候一两小时也是有可能的
4.安装those工具,参考http://iphonedevwiki.net/index.php/Theos/Setup提供的安装方法1).打开终端.2).选择theos的安装目录,官方建议放在默认的 /opt/theos.然后执行
export THEOS=/opt/theos
如果你选择的是用户之上的目录,需要加上sudo指令:
		sudo export THEOS=/opt/theos当安装教程有如下语句的时候Using git: 
git clone --recursive git://github.com/DHowett/theos.git $THEOS

Alternatively, you can use svn, if you prefer: 
svn co http://svn.howett.net/svn/theos/trunk $THEOS

不要执行上面的语句,用下面的方法替换 
git clone -b stableversion https://github.com/haorenqq/theos/ $THEOS
(特别感谢网名为逍遥笛子 的热心朋友 提供的分支,由于原theos最新的版本不兼容iosopendev,所以用15年的老版本,地址如下(已经得到该名朋友的同意))
3).之后可以下载ldid工具到those的bin目录下 执行./make.sh方法之前,需要注意:默认ldid文件夹是不带openssl文件夹的,但是make.sh中却包含#include <openssl/err.h>语句下载附件,解压,将附件中的openssl 文件夹放到 ldid 文件夹下make.sh中的代码默认是只匹配Xcode5-1-1的名称的,如果你的xcode不是这个名称,则会报错,所以下面的方法是修改make.ssh文件默认的是Xcode这个名称打开make.sh文件,找到这一行
sudo xcode-select --switch /Applications/Xcode5-**.app
将Xcode5**.app改为Xcode.app,下面还有一行也一样要修改(或者直接将附件的make.sh放入ldid文件夹下替换同名文件)修改完成之后应该是:
sudo xcode-select --switch /Applications/Xcode.app

之后在终端执行如下语句就可以了
git clone git://git.saurik.com/ldid.git
cd ldid
git submodule update --init
./make.sh
cp -f ./ldid $THEOS/bin/ldid

5.打开附件里面的Specifications文件夹,里面应该有8个文件,iPhoneOS开头的四个文件放到下面的目录下(如果没有,请自己创建一个)
/应用程序/Xcode/Content/Developer/Platforms/IphoneOS.platform/Developer/Library/Xcode/Specifications

iPhone Simulator 开头的另外四个文件放入下面的目录下(如果没有,请同样创建一个)。
/应用程序/Xcode/Content/Developer/Platforms/iPhoneSimulator.platform/Developer/Library/Xcode/Specifications


之后再下面的目录下创建usr文件夹,usr文件夹下再创建一个名为bin的文件夹
/应用程序/Xcode/Content/Developer/Platforms/iPhoneSimulator.platform/Developer/

之后的目录应该是
/应用程序/Xcode/Content/Developer/Platforms/iPhoneSimulator.platform/Developer/usr/bin


作者的这个只有简单的If else循环,所以如果不创建相对应的文件夹,它是不会自己创建的,只会报错,然后显示安装错误
做完这一切之后,就可以去下载安装了
接下来安装iOSOpenDev,在官网下载最新的版本,进行安装
这篇文章只是给出了除了作者的错误之外的相对的解决办法,另外最好按照作者那篇帖子(https://github.com/kokoabim/iOSOpenDev/wiki/Troubleshoot),比如在终端执行system_profiler SPDeveloperToolsDataType,拷贝Location:后面的信息,再复制到sudo code-select -switch location:后面的信息,执行代码,再安装iosOpenDev,另外还有另一个Xcode Lincese的问题,都在作者的帖子中有解答之后安装就不会报错,目前进行到这一步,如有进展,再更新
下面可以开始编写第一个helloworld了原作者lynjay:

按照http://blog.csdn.net/lynjay/article/details/7936488这个帖子,从帖子中的第五步开始配置iosOpenDev的环境

在终端执行~/.bash_profile
~/.bash_login
 or 
~/.profile
.这3个文件你在你电脑中看是否能找到,我是找到
~/.bash_profile
这个文件,然后设置下面的环境变量
export iOSOpenDevPath=/opt/iOSOpenDev

export iOSOpenDevDevice=
 非固定值,用户需要先在已经越狱的iphone上点击设置-网络-查看当前网络的IP地址,填入
export PATH=/opt/iOSOpenDev:$PATH

export PATH=/opt/local/bin:$PATH

export PATH=/opt/local/sbin:$PATH


接下来给SSH添加签名,在Mac的Terminal里输入”iosod sshkey -h <设备IP>”,中间问你是否继续,当然yes.如果期间失败了重新试下.我失败了好几次.可能是设备屏幕关闭会断网(我的iPod Touch总断,iPad就不会).这样就不用密码也可以登陆设备SSH了.
之后可以打开Xcode选择iosOpenDev-Logos Tweak,创建一个新的应用


创建后会出现一个.xm文件一个.mm文件,不要编辑.mm文件
因为还不能正常编译,不要担心xm文件中有这样一段说明#error iOSOpenDev post-project creation from template requirements (remove these lines after completed) -- \Link to libsubstrate.dylib: \(1) go to TARGETS > Build Phases > Link Binary With Libraries and add /opt/iOSOpenDev/lib/libsubstrate.dylib \(2) remove these lines from *.xm files (not *.mm files as they're automatically generated from *.xm files)
意思是要把libsubstrate.dylib添加到工程中(在安装好的/opt/iOSOpenDev/lib 目录下),然后把xm中的内容清空。mm文件的内容会根据xm文件中的内容编译后自动生成。之后清空.xm文件的内容,输入下列内容[objc] view plain copy <span style="font-family:Comic Sans MS;font-size:12px;">#import <UIKit/UIKit.h>  
  
%hook SpringBoard  
  
- (void)applicationDidFinishLaunching:(id)application{  
    %orig;  
      
    UIAlertView * alert = [[UIAlertView alloc]initWithTitle:@"Welcome" message:@"HelloWorld!" delegate:nil cancelButtonTitle:@"Thanks" otherButtonTitles:nil];  
    [alert show];  
}  
%end</span>  

现在调试越狱设备,在已经越狱的手机上打开Cydia,搜索下列插件
如果搜索不到,打开软件源-编辑 删除BigBos和ModMyi,再回到首页,点击更多软件源,重新添加这两个即可搜索到下列插件Core UtilitiesCore Utilities(/bin)diskdev-cmdsfile-cmdssystem-cmdsMobileterminalopenSSHsshpasstoggle sshpreferencdloadersubstrate safe modesyslogd to /var/log/syslog

再在Xcode中的Target的Build Settings中的Code Signing中,改为Don't Code Sign


最后打开Target-Build Settings 找到iOSOpenDevDevice选项,填入越狱手机的本地ip点击Product- Build For -Profiling启动应用手机会重启,之后在锁屏界面就会弹出AlertView



其他问题:
1.可能会碰到真机连接后无法编译的现象,修改build setting中的iOS Deployment Target为你的设备对应的版本即可
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: