一些常見工具均可以經過 homebrew 或 homebrew-cask 安裝java
brew install apktool
brew install smali
brew install dex2jar
brew install jadx
brew cask install jd-gui複製代碼
Android Studio 自帶的 APK Analyzer 可直接查看APK內的 圖片,xml內容,dex結構,文件尺寸等,還能夠比較兩個apk的差別。android
雖然不能導出資源有點惋惜,但已經很強大方便了。git
用法:將 apk 拖入 AndroidStudio 就行了github
參考:developer.android.com/studio/buil…segmentfault
apk 雖然其實是個 zip 能夠直接 unzip,但裏邊的 xml 都是 Binaray XML
形式,須要再次轉化成 xml 才能查看。bash
apktool 能夠將 apk 內的資源所有提取出來,同時 xml 也轉化好可直接查看內容。工具
apktool 也能夠用於在修改資源後從新打包 apk源碼分析
用法:ui
// 提取資源
apktool d test.apk
// 提取資源並指定輸出目錄
apktool d test.apk -o test
// 從新打包apk
apktool b test複製代碼
參考:ibotpeaches.github.io/Apktool/
baksmali 可將 dex/odex 轉成 .smali 文件集
smali 可將 .smali 文件集 轉成 dex/odex
注:odex 轉 smali 須要相應系統的 framework,adb pull /system/framework
用法:
// 將 test.dex 分解到 test 目錄
baksmali test.dex -o test
// 將 test 目錄裏的 smali 文件組裝到 haha.dex
smali test -o haha.dex
// 獲取系統 framework
adb pull /system/framework
// 將 test.odex 分解到 test 目錄
baksmali test.odex b framework -o test複製代碼
參考: github.com/JesusFreke/…
下載:bitbucket.org/JesusFreke/…
dex2jar 可將 .dex 轉換成 .jar
用法:
// 將 test.dex 轉成 test.jar 文件
d2j-dex2jar test.dex -o test.jar複製代碼
參考: github.com/pxb1988/dex…
下載:bitbucket.org/pxb1988/dex…
jadx 能夠將 .dex/.jar/.class
文件反編譯成 .java 源碼
jadx 也能夠直接反編譯 .apk 並處理好資源(Banary xml -> xml)
jadx-gui 可視化查看工具
用法:
// 反編譯 test.dex 並輸出到 test 目錄
jadx test.dex -d test
// 反編譯 test.apk
jadx test.apk -d test
// 反編譯 test.jar
jadx test.jar -d test
// 反編譯 test.class
jadx test.class -d test複製代碼
jd-gui 可視化反編譯查看 .jar 文件
參考:jd.benow.ca/
APK 在線反編譯
www.javadecompilers.com/apk
反編譯apk的步驟
segmentfault.com/a/119000000…
手把手教你逆向分析 Android 程序
segmentfault.com/a/119000000…
Android逆向之旅---反編譯利器Apktool和Jadx源碼分析以及錯誤糾正
blog.csdn.net/jiangwei091…