- Published on
Inspect the View Hierarchy of Any iOS Apps in 2019
- Authors
- Name
- Tong
If you're an iOS Developer. You've probably heard of Reveal.
It's a powerful runtime view debugging tool for iOS developers.
If you have a jailbroken iOS device. You're possible to debug any other's apps without having its source code.
Read Peter Steinberger's post How to Inspect the View Hierarchy of Third-Party Apps.
I'll show you how to inspect with iOS 12.
data:image/s3,"s3://crabby-images/63ee0/63ee0fdea072469d91b9a63681f5012bb774268d" alt="Reveal-App-Store.png"
Preparing
Install Reveal
brew cask install reveal
Jailbreak an iOS device. My tutorial.
Install Xcode
mas install 497799835
Installing
Checkout my GitHub fork of Reveal2Loader
git clone https://github.com/HackingGate/Reveal2Loader.git
cd Reveal2Loader
Build .deb
package
make clean
make
make package
Upload .deb
package to jailbroken iOS device
scp releases/debs/naville.revealloader2_1.0.0-1_iphoneos-arm.deb [email protected]:~/
SSH login in jailbroken iOS device
Install .deb
. It will download RevealServer.zip form my download center. And set everything up.
dpkg -i naville.revealloader2_1.0.0-1_iphoneos-arm.deb
Inspecting
On your jailbroken device. Open Settings -> Reveal
data:image/s3,"s3://crabby-images/0c711/0c71147a0dc1806030e3456fc434a8dc2bbadf86" alt="Settings-Reveal.png"
Enable applications you want to inspect
data:image/s3,"s3://crabby-images/79dc0/79dc0e6eca81f20f9526fcab95a349b4e43af3eb" alt="Reveal-Enable.png"
Open Reveal.app. You'll see inspectable apps appear.
data:image/s3,"s3://crabby-images/e7ebb/e7ebb94083e5d57b5844ff76a7b7cbe2c3d42ad3" alt="Reveal-App.png"
Reveal only works on Apple's own UI framework. Frameworks such as Flutter only shows one layer.
data:image/s3,"s3://crabby-images/9c7f9/9c7f9e396018d629fd63080557f5e1b3f8b5bf82" alt="Reveal-FlutterView.png"
Pinterest is using ASCollectionView for its waterfall layout.
data:image/s3,"s3://crabby-images/f3081/f308151f5385eb7beb3a23b2e1bc581cf1688f2a" alt="Reveal-Pinterest.png"
Pixiv ScrollView for image zoom.
data:image/s3,"s3://crabby-images/5e42c/5e42c536c5b935bd08e19af31cbaa42f88a9f98c" alt="Reveal-Pixiv.png"