如何使用apktooljar進行反編譯?
1.下載反編譯工具 需要下載四個工具:dex2jar、JD-GUI、apktool、apktool-install-windows-r05-ibot dex2jar:將apk中的classes.dex轉化成Jar文件。 JD-GUI:反編譯工具,可以直接查看Jar包的源代碼。 apktool:反編譯工具,通過反編譯APK中XML文件,直接可以查看。 apktool-install-windows-r05-ibot:輔助windows批處理工具。
2.解壓縮APK包 apk文件也是一種常見的zip,常用的壓縮軟件就可輕松地解壓apk文件。用壓縮軟件將apk文件中的文件解壓到一個文件夾中,得到APK中的資源包括XML文件和classes.dex文件,classes.dex就是java文件編譯再通過dx工具打包而成的。
3.反編譯dex文件 解壓apk文件后,你會發現res目錄的圖片沒有加密,但java源碼編譯成了一個classes.dex文件,無法用普通的反編譯class文件的方法來處理,dex2jar可以將dex文件轉換成普通的jar包。 解壓下載的dex2jar,把解壓后的文件夾放到系統盤跟目錄中并把這個目錄加到系統path變量中,就可以直接用:dex2jar.bat或dex2jar.sh轉換dex文件了。 DOS行命令如下:dex2jar.bat xx\classes.dex(xx是classes.dex文件所在的路徑)。 將在同目錄得到普通jar包:classes_dex2jar.jar,就可以用處理普通jar包的方法來反編譯這個jar包得到原文件。
4.反編譯jar包 得到jar包后,下載自已喜歡的反編譯工具,推薦使用JD-GUI,有比較簡單的圖形界面,可以反編譯單個class文件,也可以反編譯jar包,比較方便。 打開壓縮文件JD-GUI,運行jd-gui.exe,打開上面生成的jar包,即可看到源代碼了。
5.反編譯xml文件 打開解壓的res\layout目錄,有很多xml文件,如果你想看下作者是如何設計界面的,你會很失望,因為你看到的是一大堆亂碼!這個時候我們需要用到的是apktool。 具體操作方法:將下載的apktool和apktool-install-windows-r05-ibot兩個包解壓到同一個文件夾下,這個文件夾有三個文件:aapt.exe,apktool.bat,apktool.jar。把這個文件夾也放到系統盤的根目錄中并把這個目錄加到path變量中。以HelloWord.apk為例: 在DOS命令行中輸入:apktool d xx\HelloWord.apk HelloWord得到HelloWord文件夾,此文件夾中的xml文件就是編譯好的可以正常查看的文件。 這樣就得到了可以得到編譯的源碼和XML資源。 注意:文件的路徑中最好不要出現中文!