美文网首页
ios逆向开发(三)、使用Theos创建、编译、安装使用

ios逆向开发(三)、使用Theos创建、编译、安装使用

作者: 朝雨晚风 | 来源:发表于2019-04-18 18:56 被阅读0次

    1. 配置$THEOS,export THEOS=theos文件所在路径

    ztq:Desktop zhoutengquan$ mkdir MyTheos
    ztq:Desktop zhoutengquan$ cd MyTheos/
    ztq:MyTheos zhoutengquan$ ls
    ztq:MyTheos zhoutengquan$ export THEOS=/usr/local/opt/theos
    ztq:MyTheos zhoutengquan$ $THEOS/bin/nic.pl
    

    进入到我们要创建实用工具的目录中,使用export定义如下的环境变量,如下所示。下方命令比较简单,你可以这么理解,就是使用export定义了一个变量这个变量的名字是THEOS,该变量中存储的值是/usr/local/opt/theos。后边这个路径就是上述我们安装theos的路径了,如果你要使用该路径的话,使用$THEOS代替即可。当然该变量只在当前终端中可用。

    2.新建工程. $THEOS/bin/nic.pl

    接下来我们就要使用theos来创建我们的工程了,创建工程也是比较简单的,就是调用我们theos目录中bin下的nic.pl命令。具体执行如下所示。在执行nic.pl命令后,会让你选择新建工程的模板,目前theos中内置的是12套模板,当然你可以从网上下载其他的模板。当然我们此处创建的是application_modern类型的工程,所以我们就选2即可,当然,如果你想创建tweak,那么就选11即可,下方我们选择的是第二个模板。

    在选择模板后,紧接着会让你做一系列的操作,这一些列的操作和Xcode新建iOS工程的步骤类似。

    (1)输入你的工程的名字(Project Name,必选项),此处我们工程的名字是FirstTheosApplication。

    (2)输入包名(Package Name),包名的命名规则一般是你们公司域名的倒写,然后后边加上你的工程名字,此处我就随便写了一个,就是下方的com.test.firsttheosapplication。

    (3)输入作者的名字(Author/Maintainer Name), 此处我们输入的是Mr.Zhou

    (4)然后如数类名的前缀(Class name prefix), 此处我们输入的是ZTQ。
    经过上述配置后,我们的工程就创建好了。

    ztq:MyTheos zhoutengquan$ $THEOS/bin/nic.pl
    NIC 2.0 - New Instance Creator
    ------------------------------
      [1.] iphone/activator_event
      [2.] iphone/application_modern
      [3.] iphone/application_swift
      [4.] iphone/cydget
      [5.] iphone/flipswitch_switch
      [6.] iphone/framework
      [7.] iphone/ios7_notification_center_widget
      [8.] iphone/library
      [9.] iphone/notification_center_widget
      [10.] iphone/preference_bundle_modern
      [11.] iphone/tool
      [12.] iphone/tool_swift
      [13.] iphone/tweak
      [14.] iphone/xpc_service
    Choose a Template (required): 2
    Project Name (required): FirstTheosApplication
    Package Name [com.yourcompany.firsttheosapplication]: com.test.firsttheosapplication
    Author/Maintainer Name [周腾全]: Mr.Zhou
    [iphone/application_modern] Class name prefix (two or more characters) [XX]: ZTQ
    Instantiating iphone/application_modern in firsttheosapplication/...
    Done.
    
    

    下方是我们创建后的工程文件目录,当然packages文件夹是我们编译打包后才生成的文件,其中的deb就是我们的安装文件。可以将该安装包安装到我们的越狱手机上。


    编译打包后才生成的文件

    3. 编译打包前的准备工作

    打开 makefile文件,增加前四行内容

    export SDKVERSION=9.4.1.  // 你指定的Xcode版本
    export THEOS_DEVICE_IP=192.168.13.64  // 你手机的IP地址
    export ARCHS = armv7 arm64
    export TARGET = iphone:clang:latest:8.0 
    

    在指定这个设备IP之前,你要保证你的越狱设备安装了OpenSSH,并且可以在Mac的终端上进行ssh登录。


    编译打包前的准备工作

    4.进行编译 make

    做好编译前的准备工作后,紧接着就是编译我们刚才创建的工程了。首先进入到我们的firsttheosapplication目录中,执行make命令进行编译。如下所示。

    ztq:firsttheosapplication zhoutengquan$ make
    > Making all for application FirstTheosApplication…
    ==> Copying resource directories into the application wrapper…
    ==> Compiling main.m (armv7)…
    ==> Compiling ZTQAppDelegate.m (armv7)…
    ==> Compiling ZTQRootViewController.m (armv7)…
    ==> Linking application FirstTheosApplication (armv7)…
    ==> Generating debug symbols for FirstTheosApplication…
    ==> Compiling main.m (arm64)…
    ==> Compiling ZTQAppDelegate.m (arm64)…
    ==> Compiling ZTQRootViewController.m (arm64)…
    ==> Linking application FirstTheosApplication (arm64)…
    ==> Generating debug symbols for FirstTheosApplication…
    ==> Merging application FirstTheosApplication…
    ==> Signing FirstTheosApplication…
    

    5.进行打包 make package

    编译完成后,我们要讲项目进行打包,这样我们的越狱设备才能进行安装。下方是调用make package命令进行项目的打包。打包后会生成后缀名为deb的安装包。

    ztq:firsttheosapplication zhoutengquan$ make package
    > Making all for application FirstTheosApplication…
    ==> Copying resource directories into the application wrapper…
    make[2]: Nothing to be done for `internal-application-compile'.
    > Making stage for application FirstTheosApplication…
    dm.pl: building package `com.test.firsttheosapplication:iphoneos-arm' in `./packages/com.test.firsttheosapplication_0.0.1-1+debug_iphoneos-arm.deb'
    

    6.安装. make install

    将该安装包,安装到相应的越狱设备。因为上面我们已经配置了越狱设备的IP地址,并且保证该台越狱设备可以通过ssh进行连接,所以我们直接调用make install命令就可以进行项目的安装。在安装过程中会让你输入ssh登录设备的密码,输入后会显示安装成功的操作,如下所示。

    ztq:firsttheosapplication zhoutengquan$ make install
    ==> Installing…
    root@192.168.13.64's password: 
    Selecting previously unselected package com.test.firsttheosapplication.
    (Reading database ... 1738 files and directories currently installed.)
    Preparing to unpack /tmp/_theos_install.deb ...
    Unpacking com.test.firsttheosapplication (0.0.1-1+debug) ...
    Setting up com.test.firsttheosapplication (0.0.1-1+debug) ...
    install.exec "killall \"FirstTheosApplication\"" || true
    root@192.168.13.64's password: 
    Connection closed by 192.168.13.64 port 22
    ztq:firsttheosapplication zhoutengquan$ make
    

    7.安装后的效果

    下方就是我们项目安装后的效果。打开Cydia,选择已安装Tab, 会看到我们刚才安装的FirstTheosApplication(实用工具),我们可以点进去进行查看,其中的一些信息大部分是我们刚才配置的信息。到此我们一个完整的流程就走完了。


    Screen Shot 2019-04-18 at 下午5.27.08.png

    相关文章

      网友评论

          本文标题:ios逆向开发(三)、使用Theos创建、编译、安装使用

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