Android反編譯(Mac系統(tǒng)下的ApkTool、dex2jar、JD-GUI)

注意:本篇文章是本人閱讀相關(guān)文章的總結(jié),方便以后查閱,所有內(nèi)容非原創(chuàng),侵權(quán)刪。

本篇文章內(nèi)容來自于
1.Android高級(jí)進(jìn)階 顧浩鑫
2.相對(duì)應(yīng)的知識(shí)塊的最下方會(huì)給出原來的帖子的鏈接

前言

用途:用反編譯工具看某個(gè)APP是如何實(shí)現(xiàn)某個(gè)功能的。

一個(gè)APP的包中包含代碼文件和資源文件。
因此反編譯也相應(yīng)分為兩部分:
1??對(duì)資源文件的反編譯 2??對(duì)Java代碼的反編譯。

目錄

  1. 資源文件的反編譯(APKTool)
    --1.1 ApkTool的安裝
    --1.2 ApkTool的使用
  2. Java代碼的反編譯(dex2jar+JD-GUI)
    --2.1 dex2jar+JD-GUI的安裝
    --2.2 dex2jar+JD-GUI的使用

1. 資源文件的反編譯(APKTool)

Android中對(duì)資源文件的反編譯一般使用ApkTool這個(gè)工具,它可以反編譯resources. arsc、9.png和XML等文件。同時(shí)它也可以將經(jīng)過修改的反編譯文件重新打包成APK文件。

1.1 ApkTool的安裝

ApkTool支持windows/linux/mac

首先打開ApkTool官網(wǎng)安裝說明+下載地址,找到對(duì)應(yīng)的系統(tǒng)響應(yīng)的安裝說明

官網(wǎng)中Mac的安裝說明如下,則按照步驟來

**Mac OS X**:
    1.  Download Mac [wrapper script](https://raw.githubusercontent.com/iBotPeaches/Apktool/master/scripts/osx/apktool) (Right click, Save Link As `apktool`)
    2.  Download apktool-2 ([find newest here](https://bitbucket.org/iBotPeaches/apktool/downloads/))
    3.  Rename downloaded jar to `apktool.jar`
    4.  Move both files (`apktool.jar` & `apktool`) to `/usr/local/bin` (root needed)
    5.  Make sure both files are executable (`chmod +x`)
    6.  Try running apktool

第一步 得到apktool文件
1.Download Mac wrapper script (Right click, Save Link As apktool)
即打開wrapper script頁面,將該頁面的內(nèi)容另存為apktool文件

第二步:得到apktool.jar文件
1.Download apktool-2 (find newest here)
2.Rename downloaded jar to apktool.jar
即到ApkTool托管地址下載最新的版本,并重命名為apktool.jar

第三步:配置apktool命令
4.Move both files (apktool.jar & apktool) to /usr/local/bin (root needed)
5.Make sure both files are executable (chmod +x)
即將apktool.jar和apktool兩個(gè)文件移動(dòng)到/usr/local/bin目錄中(需要有root權(quán)限),同時(shí)通過命令chmod +x給這兩個(gè)文件增加可執(zhí)行權(quán)限。

appledeMacBook-Pro:~ apple$ chmod +x  /usr/local/bin/apktool.jar

注意apktool這個(gè)腳本是為了方便我們?cè)诿钚蠺erminal中直接執(zhí)行apktool命令而增加的,不使用這個(gè)腳本,則運(yùn)行ApkTool工具的命令為:

appledeMacBook-Pro:~ apple$ java -jar /usr/local/bin/apktool.jar

1.2 ApkTool的使用

第一步: 首先得到一個(gè)APK文件,然后在命令行中進(jìn)入這個(gè)文件所在目錄,執(zhí)行命令apk

//進(jìn)入文件所在目錄
appledeMacBook-Pro:Desktop apple$ cd /Users/apple/Desktop/androddemo/ProguardDemo/app/build/outputs/apk/release

//執(zhí)行命令
appledeMacBook-Pro:release apple$ java -jar /usr/local/bin/apktool.jar d app-release.apk
//如果配置了apktool 則為apktool d app-release.apk

第二步:反編譯成功后,在APK同級(jí)目錄中得到新的目錄。


其中包括明文形式的圖片資源、布局文件資源、動(dòng)畫資源以及APK代碼的smali文件等。
我們也可以通過修改其中的某些資源文件或者smali文件,然后通過命令apktool b test重新打包成APK。

2. Java代碼的反編譯(dex2jar+JD-GUI)

2.1 dex2jar+JD-GUI的安裝

反編譯java代碼的常用工具是dex2jar,查看反編譯后的結(jié)果是JD-GUI。
JD-GUI下載地址
dex2jar下載地址1
dex2jar下載地址2

JD-GUI安裝后意外退出的解決:

//使用 brew 進(jìn)行安裝
brew cask install jd-gui
//如果沒有brew命令,則進(jìn)行安裝
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

2.2 dex2jar+JD-GUI的使用

反編譯java代碼的常用工具是dex2jar,這個(gè)工具的輸入是APK文件中的classes.dex文件,輸出是一個(gè)jar文件。而這個(gè)jar包用JD-GUI來查看。

第一步:得到classes.dex文件
將xxx.apk文件解壓后(將xxx.apk改名為xxx.zip則可解壓),則得到classes.dex文件,并將classes.dex文件拷貝到dex2jar根目錄中。

問題:無法進(jìn)行解壓
解決:則用mac的unzip命令進(jìn)行解壓

appledeMacBook-Pro:~ apple$ unzip /Users/apple/Desktop/反編譯工具/app-release.zip -d /Users/apple/Desktop/反編譯工具

第二步:執(zhí)行dex2jar命令進(jìn)行反編譯
在命令行Terminal中執(zhí)行命令進(jìn)行字節(jié)碼的反編譯

//進(jìn)入dex2jar的目錄
appledeMacBook-Pro:release apple$ cd /Users/apple/Desktop/反編譯工具/dex2jar-2.0
//聲明d2j-dex2jar.sh文件執(zhí)行權(quán)利
appledeMacBook-Pro:dex2jar-2.0 apple$ sudo chmod +x d2j-dex2jar.sh
//進(jìn)行反編譯
appledeMacBook-Pro:dex2jar-2.0 apple$ ./d2j-dex2jar.sh  classes.dex

完成反編譯后,在dex2jar目錄中得到一個(gè)jar文件,


第三步:查看反編譯后的代碼
用JD-GUI打開它。
將xx.jar拖拽到JD-GUI中即可查看

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容