iOS逆向-day6:最新的 theos 使用

一、安装签名工具 ldid

  • 1.1、先确保安装了 brew,命令如下


    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"

  • 1.2、利用 brew 安装 ldid

    brew install ldid
    

二、修改环境变量 和 下载theos

  • 2.1、编辑用户的配置文件
    打开.bash_profile

    vim ~/.bash_profile
    

    提示:不熟悉 vim 的可以 open .bash_profile,修改后保存

    配置变量,在.bash_profile文件后面追加下面的 2 行

    export THEOS=~/theos
    export PATH=$THEOS/bin:$PATH
    

    提示

    • export THEOS=~/theos 配置 theos 的主路径,将来下载到哪个地方,下面 2.2 我们可以看到
    • export PATH=$THEOS/bin:$PATH 的目的是为了在任何路径下都可以找到 ~/theos/bin 下面的命令,如下面用到的 nic.pl
    • $PATH 就是引用环境变量的值

    配置立马生效

    source ~/.bash_profile
    
  • 2.2、下载 theos

    git clone --recursive https://github.com/theos/theos.git $THEOS
    

    提示

    • recursive: 代表递归的意思,因为在 gitmodules 里面存在依赖,如果不加 recursive 仅仅是下载 gitmodules 文件,不会下载依赖


    • $THEOS 等同于 ~/theos
      theos安装成功的标志

三、theos 的使用

  • 3.1、项目的类型
    终端输入 nic.pl,会有很多的项目类型,我们要是 iphone/tweak 类型,可以进行 hook

    项目的类型

  • 3.2、新建 tweak 项目

    • cd 到桌面 ,输入 nic.pl ,展示项目类型

      wangchongdeMacBook-Pro:Desktop wangchong$ nic.pl
      NIC 2.0 - New Instance Creator
      ------------------------------
      [1.] iPhone/activator_event
      [2.] iPhone/application_modern
      [3.] iPhone/application_swift
      [4.] iPhone/flipswitch_switch
      [5.] iPhone/framework
      [6.] iPhone/library
      [7.] iPhone/preference_bundle_modern
      [8.] iPhone/tool
      [9.] iPhone/tool_swift
      [10.] iPhone/tweak
      [11.] iPhone/xpc_service
      
    • 选择 10

      Choose a Template (required): 10
      
    • 项目的名字,我这里是以爱奇艺为例iQiYiPhoneVideo在后面加了tweak

       Project Name (required): iQiYiPhoneVideotweak
      
    • 包名,可以随便写一个

      Package Name [com.yourcompany.iqiyiphonevideotweak]: com.jk.iQiYiPhoneVideotweak
      
    • 作者,直接敲回车按照默认做法就行 (默认是mac上的用户名)

      Author/Maintainer Name [王冲]: 
      
    • 需要修改app的 Bundle Identifier,爱奇艺的:com.qiyi.iphone,获取一个项目的唯一标示可以使用 cycript,可以参考 第三天的博客

      [iphone/tweak] MobileSubstrate Bundle filter [com.apple.springboard]: com.qiyi.iphone
      
    • 创建完成,直接敲回车按照默认的就行

      [iphone/tweak] List of applications to terminate upon installation (space-separated, '-' for none) [SpringBoard]: 
      Instantiating iphone/tweak in iqiyiphonevideotweak/...
      Done.
      
  • 3.3、配置创建好的项目文件,以上面创建的为例 iqiyiphonevideotweak


    配置创建好的项目文件
    • 先配置 Makefile 文件,在Makefile文件的最前面加入环境变量,写清楚通过哪个 IP 和 端口访问手机

      export THEOS_DEVICE_IP=127.0.0.1
      export THEOS_DEVICE_PORT=10010
      
    • Tweak.x 去掉一些,如下,再把文件改为oc,点击右下角语言切换

    • %hook ClassName%end 之间是我们要 hook 的代码,ClassName 是我们要 hook 的类名
  • 3.4、真实演练,去掉爱奇艺下图的部分,下图使用的是 Reveal , Reveal的使用参考博客的 四

    去掉爱奇艺上图的部分
    • <1>、找到要hook 的类名,上图的是:QYIphonePreAdControlView

    • <2>、打开 爱奇艺脱壳后的 可执行文件,我使用的 Sublime 打开的,command + p 搜索 QYIphonePreAdControlView

    • <3>、修改 Tweak.x,设置要 hook 的内容

      %hook QYIphonePreAdControlView
      - (id)initWithFrame:(struct CGRect)arg1 andPlayerViewController:(id)arg2 {
           return nil;
      }
      %end
      
      • 提示: %hook 类名%end 用来放要 hook 的代码,因为我们是要去掉 QYIphonePreAdControlView,所以我们在其初始化返回 nil,那么改类的界面就会看不到

      • 可以hook多个类以及多个方法,如下

        %hook 类1
        方法1
        方法2
        %end
        %hook 类2
        方法1
        %end
        %hook 类3
        方法1
        %end
        
    • <4>、电脑的 10010 与 手机的22端口进行映射,记得电脑和手机使用线连接

      • 下载usbmuxd工具包(下载v1.0.8版本,主要用到里面的2个python脚本:tcprelay.pyusbmux.py

        tcprelay.py 与 usbmux.py

      • 将iPhone的 22 端口(SSH端口)映射到Mac本地的 10010 端口(不一定非是10010端口,只要不是保留端口就好)

        cd usbmuxd-1.0.8
        python tcprelay.py -t 22:10010
        

        提示:-t 代表可以映射多个手机的 22 端口

    • <5>、运行hook代码,生成如下图的插件,在运行 make install 的时候会安装到手机上

      cd Tweak.x 所在的文件夹
      make
      make package
      make install
      
    • <6>、可能遇到的问题

      • make 错误一

        $ make
        Error: You do not have an SDK in 
        /Library/Developer/CommandLineTools/Platforms/iPhoneOS.platform/Developer/SDKs
        

        原因:是因为多个 xcode 导致路径 (有可能安装多个 xcode),需要指定一下 xcode

        $ sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer/
        
        偏好设置里面设定 Xcode
    • make 错误二

      $ make
      > Making all for tweak xxx…
      make[2]: Nothing to be done for `internal-library-compile'.
      

      原因:是因为之前已经编译过,有缓存导致的,clean 一下即可

      $ make clean
      $ make
      
    • make package 错误
      Can't locate IO/Compress/Lzma.pm in @INC (you may need to install the IO::Compress::Lzma module) (@INC contains: /Library/Perl/5.18/darwin�thread-multi-2level /Library/Perl/5.18 /Network/Library/Perl/5.18/darwin�thread-multi-2level /Network/Library/Perl/5.18 /Library/Perl/Updates/5.18.2 /System/Library/Perl/5.18/darwin-thread-multi-2level /System/Library/Perl/5.18 /System/Library/Perl/Extras/5.18/darwin-thread�multi-2level /System/Library/Perl/Extras/5.18 .) at /Users/mj/theos/bin/dm.pl line 12. BEGIN failed--compilation aborted at /Users/mj/theos/bin/dm.pl line 12. make: *** [internal-package] Error 2
      原因:是因为打包压缩方式有问题,改成gzip压缩就行
      解决办法:修改 dm.pl 文件,用 #号注释掉下面的两句

      $ vim $THEOS/vendor/dm.pl/dm.pl
      #use IO::Compress::Lzma;
      #use IO::Compress::Xz;
      

      修改 deb.mk 文件 第六行的压缩方式为 gzip

      $ vim $THEOS/makefiles/package/deb.mk
      _THEOS_PLATFORM_DPKG_DEB_COMPRESSION ?= gzip
      
  • 3.5、每次修改改完 Tweak.x 我们都需要做 make clean && make && make package && make install 操作,这个是我放到 自己磁盘下的文件


    我们在修改完 Tweak.x 我们就可以,终端先进入 Tweak.x 所在的文件夹,然后执行 sh ~/tweak.sh

    提示:其实 make package 包含 make(编译),我们可以把 tweak.sh 里面的make 去掉,也就是下面的

    make clean && make package && make install
    

四、扩展:theos 资料查询

  • 目录结构 https://github.com/theos/theos/wiki/Structure
  • 环境变量http://iphonedevwiki.net/index.php/Theos
  • logos语法 http://iphonedevwiki.net/index.php/Logos
    • %hook、%end:hook 一个类的开始和结束

    • %log:打印方法调用详情,可以通过 Xcode -> Window -> Devices and Simulators查看日志

    • HBDebugLog:跟NSLog类似

    • %new:添加一个新的方法


      %new:添加一个新的方法
    • %c(className):生成一个 Class对象,比如 %c(NSObject),类似于 NSSTringFromClass()、objc_getClass()

    • %ctor:在加载静态库的时候调用

    • %dtor:在程序退出时调用

    • %logify.pl:可以将一个头文件快速转换成已经包含打印信息的 xm 文件

      logify.pl xx.h > xx.xm
      
  • 如果有额外的资源文件(比如图片),放在项目的 layout 文件夹中,对应着手机的根路径

五、theos-tweak 是实现过程

  • 5.1、基本过程

    • 编写 Tweak 代码
    • $ make:编译 Tweak代码为动态库 (*.dylib)
    • $ make package : 将 dylib 打包为 deb 文件
    • $ make install:将deb文件传送到手机上,通过 Cydia 安装deb
    • 插件将会安装在 /Library/MobileSubstrate/DynamicLibraries文件夹中
      • *.dylib:编译后的 Tweak代码
      • *.plist:存放着需要 hook 的 APP ID
    • 当打开app的时候
      • Cydia Subsrate (Cydia 已自动安装的插件)会让App去加载对应的 dylib
      • 修改APP内存中的代码逻辑,去执行 dylib 中的函数代码
    • 所以,theos 的tweak并不会对APP原来的可执行文件进行修改,仅仅是修改了内存中的代码逻辑
  • 5.2、疑问

    • 未脱壳的APP是否支持 tweak?
      答:支持,因为tweak是在内存中实现的,并没有修改 .app中的可执行文件
    • tweak 效果是否永久性的?
      答:取决于tweak中用到的 APP 代码是否被修改过
    • 如果一旦更新APP,tweak会不会失效?
      答:取决于tweak中用到的 APP 代码是否被修改过
    • 未越狱的手机是否支持 tweak?
      答案:不支持
    • 能不能对游戏项目进行 tweak?
      答:可以,但是游戏大多数是通过 C++或者C#编写的,而且类名、函数名会进行混淆操作

六、logify.pl 注意点

  • 6.1、logify.pl 生成的 x 文件, 有很多时候是编译不通过的,需要机型一些处理
    • 删掉 __weak
    • 删掉 inout
    • 删掉协议,比如:或者声明一下协议信息 @protocol XXTestDelegate
    • 删掉 - (void).cxx_destruct { %log;%orig;}
    • 删除 HBLogDebug(@ "= 0x%x",(unsigned int));
    • 替换类名为 void,比如将 XXPerson 替换为 void 或者声明一下类信息 @class XXPerson

/System/Library/CoreServices/SpringBoard.app/SpringBoard

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,012评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,589评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,819评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,652评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,954评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,381评论 1 210
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,687评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,404评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,082评论 1 238
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,355评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,880评论 1 255
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,249评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,864评论 3 232
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,007评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,760评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,394评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,281评论 2 259