Android APK反編譯

作為一名客戶端開發(fā)者,在使用別人Android應(yīng)用的時候,你可能會遇到一些你覺得非常不錯或者精致的布局、動畫,你想要去學(xué)習(xí)別人實現(xiàn)的想法、思路?亦或你對App中的廣告感到極其的厭倦,想使用同款服務(wù)的同時屏蔽廣告?再或者你覺得原App設(shè)計不合理,你想自己改進(jìn)體驗自己使用?當(dāng)然,你也可以處于簡單的興趣去了解Android的反編譯。這篇文章就是幫助你解決這些問題。
(注:反編譯不是讓各位開發(fā)者去對一個應(yīng)用破解搞重裝什么的,主要目的是為了促進(jìn)開發(fā)者學(xué)習(xí),借鑒好的代碼,提升自我開發(fā)水平。切記不可商用或從事違法行為。)

測試環(huán)境:
win 7

使用工具:
apktool (資源文件獲取) :該工具需要apktool.bat、apktool.jar、aapt.exe三個文件
** dex2jar(源碼文件獲?。?**
** jd-gui (源碼查看) **

官方最新版本下載地址:
** **apktool(google code):
該地址可下載apktool.bat和apktool.jar文件,aapt.exe可以在Android SDK目錄下..\Sdk\build-tools\24.0.0\aapt.exe中找到。

dex2jar(google code)** **

jd-gui(google code)

工具介紹:
apktool **
作用:資源文件獲取,可以提取出圖片文件和布局文件進(jìn)行使用查看
dex2jar
** 作用:將apk反編譯成java源碼(classes.dex轉(zhuǎn)化成jar文件)

jd-gui
作用:查看APK中classes.dex轉(zhuǎn)化成出的jar文件,即源碼文件


反編譯流程:
一、apktool工具得到APK中的源代碼、圖片、XML配置、語言資源等文件
將得到的3個文件(aapt.exe,apktool.bat,apktool.jar )保存在同一文件夾下,同時將需要反編譯的APK文件放到該目錄下,
打開命令行界面(運行-CMD) ,定位到apktool文件夾,輸入以下命令:apktool d -f test.apk -o test

(命令中test.apk指的是要反編譯的APK文件全名,test為反編譯后資源文件存放的目錄名稱,即為:apktool.bat d -f [apk文件 ] -o [輸出文件夾])

運行結(jié)束后,在同一目錄下能發(fā)現(xiàn)多了一個test文件夾,其中存放的就是反編譯后的資源文件。

如果你想將反編譯完的文件重新打包成apk,那你可以:輸入apktool b test(剛剛編譯后的文件夾名)便可,效果如下:


之后在之前的test文件下便可以發(fā)現(xiàn)多了2個文件夾:
build
dist(里面存放著打包出來的APK文件)

注1:關(guān)于以上命令的說明:可在dos命令窗口下輸入apktool命令回車獲得幫助文檔

注2:常見問題處理

問題類型:

1.Input file was not found or was not readable.2.Destination directory (C:\Users\user\a) already exists. Use -f switch if you want to overwrite it.

3.Exception in thread "main" brut.androlib.AndrolibException: Could not decode ars c fil..........
解決方案:

問題1和問題2是因為apktool升級到2.0以上時,使用方式已經(jīng)替換,格式變成了:
apktool d [-s] -f -o

問題3是因為apktool版本過低導(dǎo)致,請升級到最新版本。

二、Apk反編譯得到Java源代碼
下載上述工具中的dex2jar和jd-gui**** ,解壓
將要反編譯的APK后綴名改為.rar或則 .zip,并解壓,得到其中的額classes.dex文件(它就是java文件編譯再通過dx工具打包而成的),將獲取到的classes.dex放到之前解壓出來的工具dex2jar 文件夾內(nèi),
在命令行下定位到dex2jar.bat所在目錄,輸入d2j-dex2jar.bat classes.dex,效果如下:

在改目錄下會生成一個classes_dex2jar.jar的文件,然后打開工具jd-gui文件夾里的jd-gui.exe,之后用該工具打開之前生成的classes_dex2jar.jar文件,便可以看到源碼了,效果如下:


被混淆過的效果圖(類文件名稱以及里面的方法名稱都會以a,b,c....之類的樣式命名):

三、 圖形化反編譯apk(本人未使用過)
上述步驟一、二講述了命令行反編譯apk,現(xiàn)在提供一種圖形化反編譯工具:Androidfby
首先,下載上述反編譯工具包,打開Androidfby目錄,雙擊Android反編譯工具.exe,就可以瀏覽打開要反編譯的apk


通過反編譯,你可以獲知該應(yīng)用用到了什么第3方的庫文件,它的代碼是如何編寫的等等。
然而,如果該APK進(jìn)行了混淆處理,那么你看到的類文件名稱以及里面的方法名稱都會以a,b,c....之類的樣式命名,所以你可以想找到你所想得知的界面代碼可能會十分費勁,找到了代碼可能看起來也會很費勁,可是一個大體的思路會獲得,有了這個思路,你就可以自己去嘗試了。

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

相關(guān)閱讀更多精彩內(nèi)容

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