iOS逆向工程之Theos

来源:http://www.cnblogs.com/ludashi/archive/2016/08/17/5714095.html
-Advertisement-
Play Games

如果你對iOS逆向工程有所瞭解,那麼你對Tweak並不陌生。那麼由Tweak我們又會引出Theos, 那麼什麼是Theos呢,簡單一句話,Theos是一個越獄開發工具包,Theos是越獄開發工具的首先,因為其最大的特點就是簡單。大道至簡,Theos的下載安裝、編譯發佈都比較簡單,越獄開發中另一個常用 ...


如果你對iOS逆向工程有所瞭解,那麼你對Tweak並不陌生。那麼由Tweak我們又會引出Theos, 那麼什麼是Theos呢,簡單一句話,Theos是一個越獄開發工具包,Theos是越獄開發工具的首先,因為其最大的特點就是簡單。大道至簡,Theos的下載安裝、編譯發佈都比較簡單,越獄開發中另一個常用的工具是iOSOpenDev,因為本篇的主題是Theos,所以對iOSOpenDev不做過多贅述。本篇博客的主題是Thoes的安裝及其使用。

 

一、Theos的配置與安裝

Theos的配置與安裝算是比較簡單的,按照官方給的步驟來操作,問題不大。Theos的官方文檔地址官方Wiki,其中給出瞭如何安裝和配置Theos, 本部分內容也是按照官方的Wiki來提供的,當然進行該部分操作時,要保證你本地已經安裝了Homebrew, 可以使用brew命令來安裝一些依賴包。brew其實類似於Linux中的yum或者apt-get,就是一個包管理工具。如果你本地沒有安裝brew,那麼請求自行Google,從而完成對brew的安裝。

1.安裝dpkg

sudo brew install dpkg

dpkg是Theos依賴的工具之一,dpkg是Debian Packager的縮寫。我們可以使用dpkg來製作deb,Theos開發的插件都將會以deb的格式進行發佈的。所以我在安裝Theos之前要安裝dpkg, 當然此處我們使用強大的brew來完成dpkg的安裝。安裝的具體過程如下所示:

  

 

2.安裝ldid

sudo brew install ldid

在Theos開發插件中,iOS文件的簽名是使用ldid工具來完成的,也就是說ldid取代了Xcode自帶的Codesign。下方就是ldid的安裝過程。

  

 

3.Theos安裝

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

因為我們的Theos一般是安裝在/opt/目錄下的,所以先cd到/opt目錄下,然後從github上相關的地址clone下來即可,步驟如下(下方安裝過程挺長,請耐心等待):

  

下載好Theos後,要修改一下文件的許可權,如下命令

sudo chown $(id -u):$(id -g) theos

至此,Theos安裝完畢,就可以開啟你的Theos之旅了。

 

二、使用Theos創建、編譯、安裝使用工具

上面我們搭建好Theos的環境後,接下來就開始使用我們的Theos來做些事情了。接下來我們將要使用Theos來創建一個使用工具,併進行編譯,編譯後安裝到我們的越獄手機上。接下來來看一下這一系列的步驟。

1.配置$THEOS

export THEOS=theos文件所在路徑

進入到我們要創建實用工具的目錄中,使用export定義如下的環境變數,如下所示。下方命令比較簡單,你可以這麼理解,就是使用export定義了一個變數這個變數的名字是THEOS,該變數中存儲的值是/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.ludashi.firsttheosapplication

(3)輸入作者的名字(Author/Maintainer Name), 此處我們輸入的是Mr.LuDashi

(4)然後如數類名的首碼(Class name prefix), 此處我們輸入的是CE。

經過上述配置後,我們的工程就創建好了。

  

下方是我們創建後的工程文件目錄,當然packages文件夾是我們編譯打包後才生成的文件,其中的deb就是我們的安裝文件。可以將該安裝包安裝到我們的越獄手機上。

  

 

3.編譯打包前的準備工作

export SDKVERSION=9.3

export THEOS_DEVICE_IP=ios_device_ip

接著我們要做一些編譯打包前的準備工作,SDKVERSION是編譯工程時所使用的SDK,因為本機Xcode中是9.3的SDK,所以我們知道的SDKVERSION是9.3。指定完編譯所需的SDK後,我們需要指定打包後的文件所安裝設備的IP地址,使用THEOS_DEVICE_IP來指定。下方的IP地址是一個越獄手機的IP地址。

在指定這個設備IP之前,你要保證你的越獄設備安裝了OpenSSH,並且可以在Mac的終端上進行ssh登錄。

  

 

4.進行編譯

make

做好編譯前的準備工作後,緊接著就是編譯我們剛纔創建的工程了。首先進入到我們的firsttheosapplication目錄中,執行make命令進行編譯。如下所示。

  

 

5.進行打包

make package

編譯完成後,我們要講項目進行打包,這樣我們的越獄設備才能進行安裝。下方是調用make package命令進行項目的打包。打包後會生成尾碼名為deb的安裝包。

  

 

6.安裝

make install

將該安裝包,安裝到相應的越獄設備。因為上面我們已經配置了越獄設備的IP地址,並且保證該台越獄設備可以通過ssh進行連接,所以我們直接調用make install命令就可以進行項目的安裝。在安裝過程中會讓你輸入ssh登錄設備的密碼,輸入後會顯示安裝成功的操作,如下所示。

  

 

7.安裝後的效果

下方就是我們項目安裝後的效果。打開Cydia,選擇已安裝Tab, 會看到我們剛纔安裝的FirstTheosApplication(實用工具),我們可以點進去進行查看,其中的一些信息大部分是我們剛纔配置的信息。到此我們一個完整的流程就走完了。

     

 

三、Tweak創建、編譯、打包與安裝

接下來我們要創建Tweak類型的工程,步驟與上述過程大同小異。也是需要使用nic.pl來創建,使用make編譯,使用make package打包,使用make install安裝。接下來就來看一下這一過程。

1.最終效果

開門見山,下方就是我們要實現的效果。接下來我們就要使用Theos來創建Tweak工程,下方就是我們Tweak工程要做的事情。就是當你的iPhone鎖屏開啟後,給你彈一個框,這個彈框就是我們Tweak工程Hook的代碼,下方就是我們最終實現的效果。

  

 

2.Tweak工程創建

下方就是我們Tweak工程的創建,與上述工程的創建類似,不過我們在此選擇的是Tweak模板。如下所示,我們將該Tweak工程命名為LockScreenAlter,其他配置項使用預設值即可。然後進入到我們的LockScreenAlter工程目錄中,主要有下方四個文件。

  

 

3.Makefile文件

該文件類似於配置文件,用來指定工程用到的文件、框架、庫、使用的SDK等等,將整個編譯、打包、安裝的過程進行自動化。下方就是我們Makefile中的內容,下方紅框中是創建完工程後預設的配置,上面紅框中是後來我們添加的配置。這些項指定了編譯、安裝時所需的參數,使其自動化。因為我本地的Xcode中是iOS9.3的SDK,所以下方指定的SDKVESION是9.3。

  

4.Tweak.xm文件的編寫

(1)寫hook代碼前的分析

分析這一步是至關重要的,因為這一步可以讓你明白你的代碼作用於何處。因為我們要在鎖屏的頁面進行彈框,所以我們要在相應的鎖屏頁面添加hook。下方就是我們的分析過程。經過瀏覽系統的頭文件,我們從下方路徑中找到了SBLockScreenManager.h這個文件,從文件名不難推測出該文件就是負責iPhone系統鎖屏的文件,於是乎我們對其進行hook實現。

  

 

下方是上述頭文件的內容,從內容我們更加堅信SBLockScreenManager類就是用來管理系統鎖屏的,因為其中有個欄位是用來表示是否已經鎖屏的isUILocked。該頭文件中還有一個類方法和一個對象方法。當然這個類方法明眼一看就是用來獲取該類的單例的。而對象方法lockUIFromSource……應該是用來鎖屏和解鎖的。於是乎想要在鎖屏中彈框就要在SBLockScreenManager類中的唯一的對象方法中進行操作了

  

 

(2)hook代碼的實現

下方就是在Tweak.xm中的所有代碼。是Logos語法,使用起來是比較簡單的。%hook與%end成對出現%hook後方跟的是我們要修改的類名,此處我們要對SBLockScreenManager進行修改,類似於OC中的繼承操作。%orig,用來執行修改函數的原始函數,此處可以看做是OC語法中的super,類似於調用父類的方法。下方代碼就用到這些Logos語法就足以在鎖屏出進行彈框了。

  

常用Logos語法簡介:

  • %hook 指定需要hook的類名,以%end結尾
  • %log 用來列印log的,將信息輸入到syslog中,如%log((NSString *)@"ZeluLi")
  • %orig 執行被hook函數的原始代碼,類似於super.method功能
  • %group 該指令用於%hook的分組,%group後邊跟的是組名,%group也是必須以%end結尾,其中可以包含多個%hook
  • %init 該指令用來初始化某個%group,一個group只有被初始化後才可生效,init必須在hook中進行執行。
  • %ctor tweak的構造器,用來初始化,如果不顯式定義,Theos就會自動生成一個%ctor,併在其中調用%init(_ungrouped). 如:%ctor { %init(_ungrouped)}
  • %new 該指令用來給現有的class添加一個新的函數。與Runtime中的class_addMethod相同。
  • %c 該指令用來獲取一個類的名稱,類似於objc_getClass。

上述就先涉及這麼多,更詳細的請參加:http://iphonedevwiki.net/index.php/Logos

 

5. control文件

control文件中存儲的內容記錄了deb包管理系統所需的基本信息,會被打包進deb包里。下方就是control中內容,其中存儲的就是一些包名、工程名、版本、作者等等,與打包安裝後在Cydia中看到的信息相同。

  

 

6、進行編譯、打包、安裝

編譯打包安裝的過程與上一部分類型,在此就只展示一下過程,不做過多贅述了。

(1)使用make命令進行編譯

  

(2)打包:make package

  

(3)安裝到手機: make install

  

 

7.從Cydia中進行查看

下方就是我們成功安裝後在Cydia中查看的截圖,安裝成功後,當你鎖屏時就會彈出一個Alter。

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 假設你創建一個資料庫時,指定其初始化大小(SIZE )非常大。例如,如下測試案例所示 USE [master]GO CREATE DATABASE [TEST] ON PRIMARY ( NAME = N'TEST_Data', FILENAME = N'D:\SQL_DATA\TEST_Data.... ...
  • 1: 新增欄位: 2:刪除欄位: 3:修改欄位名: 4:修改欄位類型: ...
  • 環境:準備測試前,我查看了一下我公司的電腦是4核的(四個子視窗) 廢話少說,直接附上代碼和結果吧 測試代碼 運行結果: 資料庫的結果: 看到了吧,確實插入了1000萬條,準確無誤 然後我就想試試20個線程,每個線程插入50萬條數據看看性能怎麼樣。結果如下: 線程越多不是好事,反而更慢。。。 當線程達 ...
  • 為了保證臨界資源的安全性和可靠性,線程不得不使用鎖,同一時間只允許一個或幾個線程訪問變數。常用的鎖有互斥量,讀寫鎖,條件變數 一、互斥量 互斥量是用pthread_mutex_t數據類型表示的,在使用之前,必須對其進行初始化,可以把它設置為PTHREAD_MUTEX_INITIALIZER(只適於靜 ...
  • 一 、安裝java jdk配置環境變數 1、 卸載原有openjdk yum -y remove java-1.7.0-openjdk* yum -y remove tzdata-java.noarch 2、 下載新的jdk 並解壓 [root@localhost java]# curl -O ht ...
  • 很多kali愛好者想把kali linux作為系統使用,但是有些win下的程式有時候也需要用到,此時需要虛擬機。 kali系統在安裝虛擬機的時候也會遇到一大堆坑,接下來是我的爬坑過程。 一波三折。 環境 :kali linux 2.0 32位 軟體 :virtualbox 虛擬機 0x01 bash ...
  • typedef struct _IMAGE_EXPORT_DIRECTORY { DWORD Characteristics; // 未使用,總為0 DWORD TimeDateStamp; // 文件創建時間戳 WORD MajorVersion; // 未使用,總為0 WORD MinorVer... ...
  • Touch ID是iPhone5S後加入的一項新的功能,也就是大家熟知的指紋識別技術。大家用得最多的可能是手機的解屏操作,不用在和以前一樣輸入手機的四位數密碼進行驗證。一方面不用擔心密碼被別人看到,另一方面也方便了自己的操作。iOS8後蘋果開放了Touch ID的API給開發者,這也給我們的app帶 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...