Android反編譯:反編譯工具和方法

Sam的部落格發表於2015-01-15

前言

開發過程中有些時候會遇到一些功能,自己不知道該怎麼做,然而別的軟體裡面已經有了,這個時候可以採用反編譯的方式,解開其他的程式,來了解一些它的做法,同時啊,還可以借鑑別人的軟體結構,資原始檔,等等,哈哈。那我就來講解一些關於反編譯相關的知識,主要分三篇,第一篇介紹反編譯的工具和方法,第二篇,介紹smali的語法,第三篇介紹如何防止反編譯,主要通過這幾篇文章,瞭解如何去做反編譯和程式碼加固。

工具

apktools-目前最強大的反編譯工具

輕鬆反編譯apk,解析出資原始檔,xml檔案,生成smali檔案,還可以把修改後的檔案你想生成apk。

支援windows,linux,mac。

下載地址:https://code.google.com/p/android-apktool/downloads/list 請自備梯子

dex2jar

將apk中的dex檔案轉換成為jar檔案,很多人不會看smali檔案,還是看java類檔案比較舒服,這個時候可以藉助這個工具來轉成java,也是支援windows,linux,mac。

下載地址:http://code.google.com/p/dex2jar/downloads/list

jd-gui

檢視jar檔案,基本可以看到Java Class檔案了,也是支援mac,windows,linux。

下載地址:http://jd.benow.ca/

apktool的命令列綜合工具推薦 apktool plus

其實是別人寫的一個工具,集合了apktool的功能,另外還支援給apk簽名。最新版本是v9update6,只支援windows系統。

下載地址:http://dl.dbank.com/c0jndlkbu4#

進行反編譯

使用apktools

在apktools目錄下執行以下命令

./apktool d pathtoapk outdir #mac linux
apktool.bat d pathtoapk outdir #window

這樣就可以反編譯成功了,可以檢視其中的資原始檔,smali檔案,當然有的app進行了特殊處理,不是全部可以反編譯的。

同時apktool還可以對反編譯後的檔案逆向成apk檔案,格式如下。

./apktool b apppath outpath

逆向後的檔案要是無簽名的需要先簽名才可以安裝。

使用dex2jar

apk檔案本身其實就是一個zip壓縮包,先講apk改成一個.zip檔案解壓後得到一個classes.dex。到dex2jar的目錄,執行以下命令.

./d2j-dex2jar.sh pathtoclasses.dex #mac linux
d2j-dex2jar.bat pathtoclasses.dex #wind

之後會生成一個jar檔案,用jd-gui開啟就可以看到其中的java程式碼了。

其他

其實我們使用的反編譯也就這些足夠了,通常很多時候無法獲取很多的程式碼,畢竟人家也有措施應對的。

相關文章