iOS Theos

作者: 突刺刺 | 来源:发表于2018-06-06 20:52 被阅读67次

    一. Theos简介

    • 摘自iphonedevwiki:Theos 是一个不需要使用Xcode,就能管理,开发和部署iOS软件的跨平台开发工具。进行越狱iOS开发扩展或者调整时,Theos是一件非常重要的工具,很多越狱开发都使用了这个工具。
    • 对于我自己来说,就是越狱开发,需要用到这个工具

    二. Theos安装

    1. 配置ldid和dpkg-deb
    • Idid用来专门签名iOS可执行文件的工具,用以在越狱iOS中取代Xcode自带的codesign。如果不安装,那么产生的deb文件就安装不到手机上。命令:
    brew install ldid
    
    • deb是越狱开发包的标准格式,dpkg-deb是个用于操作deb文件的工具,有了这个工具,Theos才能正确的把工程打包成deb文件。命令:
    brew install dpkg
    
    2. 安装Theos
    • 下载theos到指定目录
    sudo git clone --recursive https://github.com/theos/theos.git /opt/theos
    
    • 配置Theos需要的执行文件的路径为环境变量
    export THEOS="/opt/theos"
    
    3. 测试Theos是否安装成功
    • 先进入任意目录(存放新建Theos项目)
    cd /Users/Users/Documents/
    
    • 命令创建Theos项目
    /opt/theos/bin/nic.pl 
    
    • 终端会出来12个模版可选择,显示如下
    skylinedeiMac:Documents skyline$ /opt/theos/bin/nic.pl
    NIC 2.0 - New Instance Creator
    ------------------------------
      [1.] iphone/activator_event
      [2.] iphone/application_modern
      [3.] iphone/cydget
      [4.] iphone/flipswitch_switch
      [5.] iphone/framework
      [6.] iphone/ios7_notification_center_widget
      [7.] iphone/library
      [8.] iphone/notification_center_widget
      [9.] iphone/preference_bundle_modern
      [10.] iphone/tool
      [11.] iphone/tweak
      [12.] iphone/xpc_service
    Choose a Template (required): 
    
    • 选择第11个模版:iphone/tweak(不知道什么意思),直接在终端输入:11
    11
    
    • 输入tweak的工程名
    Project Name (required): tweakTestProject   (随便起)  
    
    • 输入deb包的名字(建议格式类似于bundle identifier)
    Package Name [com.yourcompany.tweaktestproject]: com.yourcompany.tweaktestproject
    
    • 输入tweak作者的名字
    Author/Maintainer Name [skyline]: 作者的名字
    
    • 输入tweak可以作用的对象的bundle identifier,也就是你需要hook的App的bundle Id,比如微信的bundle Id :com.tentcent.xin。/如果作用的对象是系统,直接根据提示填:com.apple.springboard
    [iphone/tweak] MobileSubstrate Bundle filter [com.apple.springboard]: com.apple.springboard 
    ```如果作用的对象是系统,直接根据提示填:com.apple.springboard```
    
    • 输入tweak安装完成后需要重启的应用,以进程名表示,比如系统:
    [iphone/tweak] List of applications to terminate upon installation (space-separated, '-' for none) [SpringBoard]: SpringBoard
    ```如果要重启系统就填 SpringBoard ```
    
    • 如果成功,终端就会显示
    Instantiating iphone/tweak in tweaktestproject/...
    Done.
    
    • 检查生成的文件。在前面设置的路径下(/Users/Users/Documents/),生成了一个叫tweakTestProject的文件夹
    skylinedeiMac:Documents skyline$ ls /Users/skyline/Documents/tweaktestproject 
    Makefile        control
    Tweak.xm        tweakTestProject.plist
    
    • 成功

    三. Theos文件说明

    • 上一步/Users/Users/Documents/下有四个文件
    • plist文件:
      • 需要设置多个app成为tweak的作用对象,就在Bundles数组里添加app的bundleID;
      • 需要设置多个类成为tweak的作用对象,就在Classes数组里添加类名;


    • control文件
    Package: com.yourcompany.tweaktestproject  /*deb包的名字组成部分之一*/
    Name: tweakTestProject
    Depends: mobilesubstrate  /*描述满足deb包运行的条件,如果不满足,tweak无法正常运行。比如 Depends:mobilesubstrate,firmware(>=8.0),tweak必须在高于iOS8.0系统下运行,*/
    Version: 0.0.1
    Architecture: iphoneos-arm
    Description: An awesome MobileSubstrate tweak!  /*deb包的描述,在Cydia可以看到,随意更改*/
    Maintainer: tucici  /*deb包的维护人,在Cydia可以看到,随意更改*/
    Author: tucici  /*deb包的作者,在Cydia可以看到,随意更改*/
    Section: Tweaks /*deb包所属的程序类型,不能更改*/
    
    • Makefile
    export THEOS_DEVICE_IP = 192.xxx.1.xxx /*这一步很重要,填越狱手机IP,默认文件没有这个参数,需手动设置,而且必须放在第一行*/
    include $(THEOS)/makefiles/common.mk /*THEOS就是建立Theos工程时,初始化的一个全局变量  export THEOS="/opt/theos"*/
    
    TWEAK_NAME = tweakTestProject
    tweakTestProject_FILES = Tweak.xm myclass.m city.xml/*设置工程需要引用的文件,多个文件之间用空格分隔开,可以添加自定义的文件*/
    tweakTestProject_FRAMEWORKS = UIKit /*添加TWEAK依赖的库,多个库之间用空格分隔开,默认没有,自行添加*/
    export ARCHS = armv7 arm64 /*支持处理器架构,用空格隔开,默认文件没有这个参数,默认没有,自行添加*/
    TARGET = iphone:7.0:7.0  /*指定设备为iphont : 指定Xcode用7.0版本的SDK编译 : 指定发布手机最低系统为7.0,默认没有,自行添加*/
    include $(THEOS_MAKE_PATH)/tweak.mk
    
    after-install::
        install.exec "killall -9 SpringBoard" /*表示tweak安装之后,需要杀掉的进程,killall -9 SpringBoard 就是系统重启,killall -9 WeChat就是微信重启*/
    
    • Tweak.xm
      • 用Theos创建tweak工程,默认生成的源文件是Tweak.xm。
      • “xm”中的“x”,代表这个文件支持Logos和C语法。
      • 如果后缀名是“xm”,代表这个文件支持Logos和C/C++语法。

    四. 常见问题

    • 没有找到安装的Theos,提示如下:
    Makefile:4: /makefiles/common.mk: No such file or directory
    Makefile:18: /tool.mk: No such file or directory
    make: *** No rule to make target `/tool.mk`. Stop.
    

    解决办法:重新安装Theos即可

    • Mac装有多个Xcode,提示如下:
    bash: /Applications/Xcode: No such file or directory
    ==> Error: You do not have any SDKs in /Application/Xcode 7.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs or /opt/theos/sdks
    make: *** [before-all] Error 1
    

    解决办法: 比如要指定Xcode7为活动Xcode。(Xcode的名字一定要正确,注意Xcode7和Xcode 7的区别)

    sudo xcode-select -s /Applications/Xcode7.app/Contents/Developer
    
    • 无新编译,提示如下
    > Making all for tool cargodaemon...
    make[2]: Nothing to be done for `internal-tool-compile`.
    

    解决办法:

    make clean```清除上次make命令所产生的文件```
    
    • 如图:
    Can't locate IO/Compress/Lzma.pm in @INC (you may need to install the IO::Compress::Lzma module) ...
    

    解决办法:(MacOS修改文件权限-->戳这里)
    cd /opt/theos/vendor/dm.pl/
    

    注释掉第dm.pl中的12、13行
    //use IO::Compress::Lzma;
    //use IO::Compress::Xz;

    cd /opt/theos/makefiles/package/
    

    deb.mk中第6行lzma改为gzip
    _THEOS_PLATFORM_DPKG_DEB_COMPRESSION ?= gzip

    五. 其他

    五. 参考资料

    相关文章

      网友评论

          本文标题:iOS Theos

          本文链接:https://www.haomeiwen.com/subject/znjisftx.html