常見 APK 反編譯工具安裝與使用

ezy發表於2017-04-02

reezy.me/2016-12-22/…

安裝

一些常見工具都可以通過 homebrewhomebrew-cask 安裝

brew install apktool
brew install smali
brew install dex2jar
brew install jadx
brew cask install jd-gui複製程式碼

APK Analyzer

Android Studio 自帶的 APK Analyzer 可直接檢視APK內的 圖片,xml內容,dex結構,檔案尺寸等,還可以比較兩個apk的差異。

雖然不能匯出資源有點可惜,但已經很強大方便了。

用法:將 apk 拖入 AndroidStudio 就好了

參考:developer.android.com/studio/buil…

apktool

apk 雖然實際上是個 zip 可以直接 unzip,但裡邊的 xml 都是 Binaray XML 形式,需要再次轉化成 xml 才能檢視。

apktool 可以將 apk 內的資源全部提取出來,同時 xml 也轉化好可直接檢視內容。

apktool 也可以用於在修改資源後重新打包 apk

用法:

// 提取資源
apktool d test.apk

// 提取資源並指定輸出目錄
apktool d test.apk -o test

// 重新打包apk
apktool b test複製程式碼

參考:ibotpeaches.github.io/Apktool/

smali/baksmali

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

dex2jar 可將 .dex 轉換成 .jar

用法:

// 將 test.dex 轉成 test.jar 檔案
d2j-dex2jar test.dex -o test.jar複製程式碼

參考: github.com/pxb1988/dex…
下載:bitbucket.org/pxb1988/dex…

jadx

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複製程式碼

參考:github.com/skylot/jadx

jd-gui

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…

相關文章