iOS逆向教程之logify跟蹤方法的調(diào)用
前言
根據(jù)上一篇文章的介紹,我們將App的頭文件使用 class-dump 導(dǎo)出后,然后利用 theos 創(chuàng)建逆向的工程,編寫 hook 的代碼,從而達(dá)到修改某些功能的目的。但是有時候某些功能具體調(diào)用哪個方法我們不好定位,這時候就用到了 logify 來跟蹤函數(shù)調(diào)用,從而定位到我們需要的函數(shù)。
logify 是 theos 的一個組件,logify 可以將一個頭文件快速轉(zhuǎn)換成已經(jīng)包含打印信息的xm文件。當(dāng)然如果某個類中的方法很少,你完全可以自己手動添加 NSLog 的打印信息,但是某個文件中的方法很多的時候,收到給每個方法添加日志信息,會浪費很多很多時間,logify 便是一個不錯的工具。
logify是theos的一個組件,路徑是:
/opt/theos/bin/logify.pl
我們以微信的聊天界面為例,假如在當(dāng)前界面我收到紅包消息的時候,我想確定是響應(yīng)了哪個方法,方便分析搶紅包的后續(xù)操作。
步驟
我們利用 Reveal 確定出了群聊界面的控制器名稱為 BaseMsgContentViewController 并且利用 class-dump 將頭文件導(dǎo)出,這個類中的方法特別多,接下來我們利用 logify 把該文件快速轉(zhuǎn)換成已經(jīng)包含打印信息的xm文件。
// 導(dǎo)出已添加日志信息的xm文件 logify.pl BaseMsgContentViewController.h > Tweak.xm
然后創(chuàng)建 theos工程,用我們剛才生成的 Tweak 替換剛才創(chuàng)建的 theos 項目的Tweak.xm。然后重新編譯打包安裝。
錯誤解決
logify.pl 生產(chǎn)的xm文件,有很多時候是編譯不通過的,需要進行一些處理。
- 刪除 __weak
- 刪除 inout
- 刪除協(xié)議 ,或者在頭部聲明一下協(xié)議,@protocol XXXDelegate
- 刪除 HBLogDebug(@" = 0x%x", (unsigned int)r)
- 替換類名為 void * ,比如將 XXPerson * 替換為 void * 因為都是指針類型?;蛘咴陬^部聲明一下,@class XXPerson
根據(jù)自己編譯的時候報的具體錯誤,進行適當(dāng)?shù)男薷募纯伞?br />
日志查看
theos 工程重新打包安裝成功后,重新打開微信的聊天界面,然后打開 Xcode -> Window -> Devices and Simulators 即可跟蹤方法的調(diào)用。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
iOS中UITableView Cell實現(xiàn)自定義單選功能
本篇文章主要介紹了iOS中UITableView Cell實現(xiàn)自定義單選功能,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02iOS支付寶、微信、銀聯(lián)支付集成封裝調(diào)用(下)
本篇文章通過代碼實例給大家講述了iOS支付寶、微信、銀聯(lián)支付集成封裝調(diào)用,對此有需要的朋友可以測試參考下。2018-04-04