apktool + dex2jar + xjad反编译apk文件
要想反編譯apk文件,得先了解apk文件的生成原理,這樣才懂的靈活反編譯apk文件。
apk文件是把Android項目工程通過sdk-->build-tools-->aapt.exe打包成apk文件,sdk也提供了一個dexdump.exe來反編譯出來,但這個并不好使,反編譯只是把dex文件反編譯成Smali文件,這種代碼還不夠易讀。
現在我就反編譯新浪客戶端來具體講解反編譯流程,首先下載一個新浪客戶端的apk文件,再通過解壓工具解壓apk文件,可以解壓出一個文件夾,可知,apk文件就是一個壓縮包。發現解壓后的文件除了一些圖片都是亂碼,所以我們先把解壓縮的文件和完成Android工程目錄結構進行對比。
? ?? ?? ? ? ? ? ? ? ? ? ? ? ? ?完整目錄結構: ?
對比可知:我們可以猜測,解壓后沒有的文件夾都被編譯到.dex文件中去了,所以反編譯apk還需要反編譯dalvik二進制文件dex和壓縮的XML文件。
下面就針對以上的問題進行反編譯:
第一步:利用apktool工具把被壓縮的XML文件反編譯出來。把從網上下載下來apktool.jar文件放到sdk-->platform-tools中,方便使用。再按如下操作:
apktool d 要反編譯的文件 ?反編譯都放置的位置
·
這樣反編譯發現比dexdump好多了,至少XML文件可以看了,但java源碼還只是Smali文件,所以我們還需要反編譯dex文件,這就需要之前解壓出來的dex文件了
java --> class --> dex --> apk ? ? ? --------------> ? ? 逆向反編譯:apk --> dex --> jar --> java
第二步:利用dex2jar工具來把dex文件反編譯成jar
dex2jar classes.dex?
第三步,利用Xjad工具把jar包反編譯成java文件
最后把反編譯的java文件都拷到apktool工具反編譯出的文件中去,大功告成。
總結
以上是生活随笔為你收集整理的apktool + dex2jar + xjad反编译apk文件的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VCPKG安装和使用教程
- 下一篇: Acrobat专业版破解补丁AMTEmu