"深入解讀:探索Reveal調試工具的奧秘"

在文章開始前,我想分享一個小插曲:

事情是這樣的,逆向群里有個小伙伴,看了上一篇("探秘工具:MacOS工具探索")文章后,對Reveal工具的使用不是很了解,感謝小伙伴能夠聯系我,本篇文章將會對Reveal詳細介紹.

如果你閱讀了前幾篇文章后,有任何疑問或者覺得有哪些地方需要補充,都可以隨時聯系我,我會盡力保證文章質量。

正如這位小伙伴一樣,我可能會忽略一些東西,但這些東西可能正是你感興趣的。我會努力完善知識,分享給大家,這是一件挺好的事情。

Reveal

1.Reveal介紹

Reveal下載地址:Reveal
Reveal是一個用于查看程序界面結構和調試界面的工具,可以直觀的查看應用的UI布局.

Reveal

通過高級可視化、全面的檢查器和動態修改應用程序的能力,您可以在幾秒鐘內調試視圖布局和呈現問題。

  • Reveal是一款運行在Mac OS上的應用,現在有免費的Beta版本可供下載。要調試iOS應用,開發者要將應用程序與Reveal安裝的框架層關聯。

  • Reveal會掃描其網絡中關聯的應用程序,并讓開發者選擇連接其中之一,當連接到一個應用程序后,Reveal將顯示其UI,其中包括大量的參數和設置。

  • 開發人員現在可以檢查UI或者更改設置,直到用戶界面的外觀和行為達到預期目標。目前它尚不支持布局約束,但根據Reveal的支持文檔來看,這一功能將在未來的版本中發布。

  • Reveal可以和iOS模擬器一起使用,也可以用在運行在真機上的應用程序上。另外,Reveal的安裝只需幾分鐘。

  • 除了解析出UI參數外,Reveal也會通過一個分解的3D視圖顯示復雜的UI層次結構。開發者可以輕松的檢查UI組件的分層,并在其層次結構中選擇特定元素。為了進一步簡化調試,也可以僅關注部分UI,而把其余部分屏蔽起來。

介紹了這些,基本了解了Reveal的基本功能.

2.RevealServer.framework 如何獲取?
  • Reveal下載好后,我們打開看看
Reveal
  • 這就是下載的Reveal應用,看上去就很酷.
    這里不是重點,我們首先獲取RevealServer.framework,怎么獲取呢?
iOS Library
  • 選中 Reveal -> 導航欄 Help -> Show Reveal Library in Finder -> 有兩個Library (iOS Library ; tvOS LIBrary),我們這里只關注iOS Library.

  • 我們點擊進入iOS Library文件夾

RevealServer.framework

可以看到RevealServer.framework文件.到這里,我們已經獲取到了RevealServer.framework.

你已經知道了怎么去獲取RevealServer.framework了.

3.RevealServer.framework如何在項目中使用?
  • 我們新建Xcode項目工程,命名為TEST
  • 我們把剛才的RevealServer.framework 拖進項目
新建Xcode項目并RevealServer.framework拖進工程
  • 我們運行一下真機,看看效果.
運行后Xcode崩潰了

真機運行后,Xcode崩潰了.

dyld: Library not loaded: @rpath/RevealServer.framework/RevealServer Referenced from: /var/containers/Bundle/Application/B5E77A27-B9C1-488B-9ABD-79F3FED77D1C/TEST.app/TEST Reason: image not found

報錯原因是鏡像沒有發現

  • 如何解決這個問題呢?
解決崩潰的辦法

我們只需要在Embedded Binaries中導入RevealServer.framework,運行真機看一下是否還會崩潰.

項目已經正常運行.
到這一步,你已經可以完成了一大半的任務了.

  • 我們在ViewController中創建一個Button,下面是代碼
#import "ViewController.h"

@interface ViewController ()

@property (nonatomic,strong)UIButton *revealBtn;

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    
    [self.view addSubview:self.revealBtn];
}

-(UIButton*)revealBtn{
    if (!_revealBtn) {
        _revealBtn = [UIButton buttonWithType:UIButtonTypeCustom];
        _revealBtn.frame = CGRectMake(100,100, 100,40);
        _revealBtn.backgroundColor = [UIColor redColor];
        [_revealBtn setTitle:@"測試" forState:UIControlStateNormal];
        [_revealBtn setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];
    }
    return _revealBtn;
}

@end

  • 運行之后是這樣的頁面
運行結果

代碼只是簡單地創建了一個具有紅色背景的按鈕。
對于這樣的項目,我們并不需要過于復雜的設計,只是簡單地演示一下即可。

  • 接著,我們看看Reveal應用發生了什么變化?
    我們打開Reveal應用
運行項目后的Reveal應用
  • 我們點進去看一下
運行結果

Reveal運行結果和我們真機運行結果是一模一樣的,現在是2D的畫面

  • 我們看一下3D的畫面
畫面層級

左側是視圖層級,通過3D畫面可以清晰地看出層級的層次。

通過這種方式,我們可以輕松地了解界面的層級以及所使用的類,一目了然。

不論是分析某些應用,還是分析自己開發的項目,對界面的優化和分析都有很大的幫助。

  • 到這里,你已經知道了如何在自己的項目中使用Reveal。

注意

如果你需要上架AppStore,Reveal不可以和項目一起提交的,在這里要特別注意
4. CoacoaPods集成
  • 開發最簡單的方式就是通過pod集成
  • 我們在Podfile中配置后,進行配置安裝
pod集成
# Uncomment the next line to define a global platform for your project
platform :ios, '9.0'

target 'TEST' do
  # Comment the next line if you don't want to use dynamic frameworks
  use_frameworks!
   pod 'Reveal-SDK', :configurations => ['Debug']
  # Pods for TEST

end

configurations 設置表示只有Debug模式下開啟,如果release是關閉狀態.

  • pod install進行集成
pod install
  • 集成之后,我們直接運行項目,同上面的結果
  • 打開reveal,也是同樣的界面

我相信你已經學會了兩種方式使用Reveal

5.如何在越獄設備中安裝Reveal呢?
  • 在平常開發中,如果你有越獄設備,那就非常好了.
  • 如果我們有個功能或者界面布局,你想參考其他APP的功能,你就可以通過越獄設備,在Cydia中安裝Reveal.
  • 一般我們不借助類似Reveal的軟件,我們是不能查看從AppStore下載的應用,為什么這么說?
    我們沒有辦法把reveal注入到程序內部,所以你查看不到.
    上面的兩種方式,我們是主動注入到項目里的,這樣我們可以查看到項目的界面結構

考慮
如果我們沒有辦法注入到想要查看的項目,我們有沒有其他的方式呢?
答案是有的

  • 我們可以通過越獄設備中安裝Reveal,來達到瀏覽項目結構的目的
  • 我們找到Cydia,并打開,搜索reveal Loader
reveal Loader
  • 我們點擊reveal Loader,并安裝
7A286D79-08DE-446A-8A2F-21DB343E0F42.png
  • 安裝1


    安裝中1
  • 安裝2


    安裝中2
  • 當我們安裝完后,會提示你重啟SpringBoard,我們進行重啟就可以了.

  • 重啟完成后,我們可以在手機 設置 -> Reveal

安裝后的Reveal
  • 點擊reveal
點擊進入reveal
  • 找到TEST 開啟權限
找到TEST 開啟權限

注意
是不是可以通過Reveal應用查看指定的應用呢?
答案是不可以.
我嘗試很久,沒有成功,最終找到了原因.

解決Reveal無顯示的問題?
  • 1.我們需要從RevealServer.framework找到RevealServer
RevealServer
  • 2.把RevealServer重命名為libReveal.dylib
libReveal.dylib 和 libReveal.plist
  • 3.并制作libReveal.plist文件,libReveal.plist內需要寫入的內容
libReveal.plist
<dict>
    <key>Bundles</key>
    <string>com.apple.AppStore</string>
</dict>
  • 4.把它們拷貝到手機的/Library/MobileSubstrate/DynamicLibraries/ 的目錄下.


    /Library/MobileSubstrate/DynamicLibraries/
  • 5.重啟啟動手機后,可以查看需要瀏覽的應用.
    完美越獄手機重啟后不受影響
    非完美越獄手機需要重新越獄

  • 6.打開Reveal 查看下應用

Reveal 1
Reveal 2
6.總結

通過本篇文章的學習,相信你對Reveal有了深刻的了解,知道如何使用它了。
主要講了三種方式使用Reveal:

  • 通過使用Reveal自帶的Framework
  • 通過使用pod集成
  • 通過越獄設備安裝Reveal,并對其他應用進行界面結構查看。
  • 另外,除了使用iFunBox拷貝文件,還可以使用終端命令scp。

希望持續關注,下篇文章會有更多精彩內容。歡迎大家留言,及時交流。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,606評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,582評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,540評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,028評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,801評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,223評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,294評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,442評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,976評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,800評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,996評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,543評論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,233評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,926評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,702評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374