用Reveal分析第三方App的UI

来源:http://www.cnblogs.com/TingyunAPM/archive/2016/03/21/5303070.html
-Advertisement-
Play Games

文章出自:聽雲博客 Reveal簡介: 這是個神奇的工具,它能常透徹地分析個App的UI結構。 這個工具包括兩部分,部分是在PC上運行的一個獨立應用,即Reveal.app,另一部分代碼在你要分析的某個App中,為此,Reveal提供了一個Framework和一個Dylib供使用。這兩部分之間通過B


文章出自:聽雲博客

Reveal簡介:

這是個神奇的工具,它能常透徹地分析個App的UI結構。

這個工具包括兩部分,部分是在PC上運行的一個獨立應用,即Reveal.app,另一部分代碼在你要分析的某個App中,為此,Reveal提供了一個Framework和一個Dylib供使用。這兩部分之間通過Bonjure這種零配置網路進行通訊。

官方地址:www.revealapp.com

基本使用:

Reveal.app的使用沒有什麼可說的,就是點擊運行。關鍵是另一部分,怎麼嵌入到App中。

我們自己的App都有源碼,因此最簡單的方式就是靜態鏈接方式集成到App中。

關於基本使用,參考幫助中的“Integration Guide”,或者參考這些鏈接。

http://blog.csdn.net/yongyinmg/article/details/39293015

http://chuansong.me/n/1308113

http://blog.csdn.net/yiyaaixuexi/article/details/18220875

真正的需求

我弱弱的問一句:我自己的UI還需要用這個工具分析?有這個需求嗎?

實際上,Reveal是一個逆向工程工具,主要是用來分析別人的App(的UI),說是學習也好、研究也好、剽竊也好,反正這個工具真正的價值和意義就是用於分析別人的App。

libReaveal.dylib的限制

要分析別人的App,需要用到libReveal.dylib,很可惜,1.5版本提供的dylib不支持ARM架構,也就是說,只能用於模擬器。搞了半天,還是只分析自己的App,Reveal,你啥意思?

其實早期版本的libReveal.dylib是支持ARM架構的,那時,只要把這個libReveal.dylib文件扔到手機的/Library/MobileSubstrate/DynamicLibraries/目錄下,就OK了。後來為何不支持ARM架構了呢?我想這裡面肯定發生了什麼事,我想可能被投訴侵權了……想啥也沒用,這個libReveal.dylib現在不好使了!

搜了一下,往前好幾個版本都不支持ARM了,再早的,官方沒的下載,據說也不能與新版的ReavealApp配合使用。

Reveal,你是不是有點尷尬?

自己做一個libReveal.dylib

別責怪Reveal了,其實人家啥都給了,不是有Reveal.framwwork嗎?它可是模擬器和真機都支持的,如果你用它自己製作一個libReveal.dylib,支持ARM架構,用來分析別人的App,那麼……“後果自負”,這絕對是Reveal的意思。

哈哈〜~不就是一個越獄插件嗎,這個容易,附件就是我做的。製作過程也有點小坑,所以也貼出來吧。

(這需要the os或者iOSOpenDev,正好我已經裝了iOSOpenDev)

打開xcode,新建一個工程,如圖: 

      3331.png                          

我的工程乾脆也叫libReveal。

工程建立了之後,我把Reveal.framework拖進來,再加一行log吧

3332.png

編譯,OK,dylib文件生產了。

拖拽過去,然後隨便打開一個App試了試,不行,Reveal.App沒有發現什麼。嗯,我預料到了,不可能這麼順!

我仔細看了一下編譯生產的這個libReveal.dylib文件,大小才150K,怎麼這麼小?

我想起來了,它嵌碼不是“零代碼”嗎?“零代碼”應該是利用了類載入機制,啟動代碼應該放在load或者initialize里,只要這個類被載入,就會執行到。

同時,還要保證這個類一定會被用到,這要用到Objective-c的category特性,很可能可能是對UIApplication做了category,這個我稍後分析一下就知道了。

如果要在動態庫中使用了OC的category特性,必須在link時告訴連接器,否則category中的代碼將不會被編譯到dylib或者framwwork中(除非明確使用到)。添加連接參數:

      3333.png

再編譯,出了六十多個錯誤,都是說xxx符號找不到,根據提示,把Foundition、UIKit、coreGraphics、QuartzCore、CFNetwork、libz加入進來(註意,Foundtion.framework本來就加進來了,需要刪掉重新加進來,否則在8.0以前的iOS上不能運行,報告找不到NSNetService,這是個小坑)。                                         

      1234.png                                

編譯,通過!這回大小1.7M(支持armv7和arm64),在拖過去試了一下,大功告成!

最後,有兩點必須說明:

1、plist文件,也就是libReveal.plist這個文件,它起過濾作用,或者說它決定你要研究那個App,你通過指定bundleId來決定哪個App/進程啟動時,這個libReveal.dylib註入進去。

2、libReveal.dylib的危險性像springboard等系統進程,你不應該註入進去,否則可能會有危險。特別是,當libReveal.plist不存在時,相當於沒有過濾,沒有限制,所有進程都會被註入。我試過刪除libReveal.dylib,真的不好玩,重啟就完蛋了,最後的代價是重新刷機。

 

原文鏈接:https://blog.tingyun.com/web/article/detail/262


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

-Advertisement-
Play Games
更多相關文章
  • 之前本來打算在寫兩個篇幅,但是在這片開寫的時候覺得還是寫一個比較好,有利於理解。NSURLSession下載是通過NSURLSession下載代理實現的,上一片也介紹了代理,之所以沒有介紹下載是因為,我個人覺得容易混淆(應該是我太笨)。這篇隨筆里將會介紹NSURLSession下載的實現,包括下載的
  • 一、已有類型的歸檔和解檔 首先來看一個簡單的例子: //第二種方式 //第一種方式的缺陷是一個對象歸檔成一個文件 //但是第二種方式,多個對象可以歸檔成一個文件 NSArray *array = [NSArray arrayWithObjects:@"zhangsan",@"lisi", nil];
  • 只有第一次運行程式才出現 ,刪除重新運行程式才會有。 我只展示最後一張圖了。 首先創建一個viewcontroller的類 然後在APPDelegate中設為根視圖 然後在 UseGuideViewController.h中寫 FirstViewController是我的主界面。 巨集定義寬和高 下麵
  • 為什麼是Dagger2 為了更好的瞭解Dagger2,請先閱讀 "RoboGuice" 篇瞭解依賴註入。 官方文檔稱,依賴註入這種技術已經在存在多年了,為什麼Dagger2要造輪子? Dagger2是第一個全部使用自動生成代碼的框架。 框架生成的代碼就像我們自己手寫的,可以輕易進行調試和測試,並且很
  • 從最開始什麼都不懂的小白,到到現在略知一二的小孩。我覺得不僅僅是我,大家應該都會註意到代理幾乎貫穿著IOS,那麼問題來了,我接下來要說什麼呢,那就是。標題的內容啦。上篇網路系列的文章我介紹了NSURLSession,趁熱打鐵,這篇就介紹一下NSURLSession代理的實現。 NSURLSessio
  • 就在不長也不短的時間前,蘋果正式命令咱們要向NSURLSession看,因此我們不得不認認真真的聽從老大的教導,努力認知NSURLSession。其實呢,三方早已為我們解決了問題,但是呢,我們還是有必要大概瞭解一下NSURLSession。下麵呢,我就為大家簡單介紹NSURLSession。 *下麵
  • selector 選擇器 在App的使用中經常能看到selector的身影 如:一個按鍵看上去白色或者其它顏色,可能是一張圖片 按下去又顯示其它的顏色或者另外一張圖片 這裡使用shape配合使用 正常狀態 按下狀態 selector 佈局中引用 有圖片就去需要建立一個selector 在drawab
  • ListView可能是Android開發中最常用的一個控制項,但要用的純熟還需要不斷的鍛煉。 建立簡單的ListView 1.在佈局文件(.xml)中添加<ListView>標簽 2.在MainActivity.java中用適配器綁定 可以看到 數組內容無法直接加到ListView中,所以要用適配器。
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...