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