【轉+原】Android代碼反編譯及分析

參考博客:

http://blog.csdn.net/ithomer/article/details/6727581


一、反編譯Apk得到Java源代碼
首先要下載兩個工具:dex2jarJD-GUI

前者是將apk中的classes.dex轉化成Jar文件,而JD-GUI是一個反編譯工具,可以直接查看Jar包的源代碼。以下是下載地址

http://code.google.com/p/dex2jar/downloads/list

http://java.decompiler.free.fr/?q=jdgui

PS:由於之前一直是隻下了別人提供的鏈接,下一次後就不更新工具了,造成後面Android版本升級後混淆功能加強,一度有段時間沒混淆工具用,但是一直沒想過要更新工具,實在是有點根號2了。。。當時剛自學Android沒多久。。

具體步驟:

首先將apk文件後綴改爲zip並解壓,得到其中的classes.dex,它就是java文件編譯再通過dx工具打包而成的,將classes.dex複製到dex2jar.bat所在目錄dex2jar文件夾。

在命令行下定位到dex2jar.bat所在目錄,運行

dex2jar.bat    classes.dex

生成

classes_dex2jar.jar

PS:亦可採用將classex.dex文件拖至dex2jar.bat處,當出現一個“+”號描述用dex2jar.bat打開也能生成classes_dex2jar.jar,這個也是我平時用的方式得意比網上介紹的方便快捷



然後,進入jdgui文件夾雙擊jd-gui.exe,打開上面生成的jar包classes_dex2jar.jar,即可看到源代碼了,如下圖:



二、apk反編譯生成程序的源代碼和圖片、XML配置、語言資源等文件

如果是漢化軟件,這將特別有用

首先還是要下載上述反編譯工具包,其中最新的apktool,請到google code下載

apktool(google code)

https://code.google.com/p/android-apktool/downloads/list


具體步驟:

下載上述反編譯工具包,打開apk2java目錄下的apktool1.4.1文件夾,內含三個文件:aapt.exeapktool.batapktool.jar 

注:裏面的apktool_bk.jar是備份的老版本,最好用最新的apktool.jar


在命令行下定位到apktool.bat文件夾,輸入以下命令:apktool.bat  d  -f   abc123.apk   abc123,如下圖:

 

上圖中,apktool.bat 命令行解釋:apktool.bat   d  -f    [apk文件 ]   [輸出文件夾]


反編譯的文件如下(AndroidManifest.xml爲例):


PS:你要反編譯的文件一定要放在C盤的根目錄裏


將反編譯完的文件重新打包成apk,很簡單,輸入apktool.bat   b    abc123(你編譯出來文件夾)即可,命令如下:

 

打包apk後的文件在目錄C:\HelloAndroid下,生成了兩個文件夾:

build

dist

其中,打包生成的HelloAndroid.apk,在上面的dist文件夾下,Ok



三、 圖形化反編譯apk

上述步驟一、二講述了命令行反編譯apk,現在提供一種圖形化反編譯工具:Androidfby

首先,下載上述反編譯工具包,打開Androidfby目錄,雙擊Android反編譯工具.exe,就可以瀏覽打開要反編譯的apk


四、分析反編譯後的R.class

由於現在大部分代碼都混淆了,反編譯後找不到R.class 
其實不然,在反編譯後的文件裏是放在res\values\public.xml裏 

然後反編譯的類裏setContentView(2130903174);是十進制的 
使用win鍵+R啓動運行窗口輸入“calc”,得到windows系統自帶的“計算器”,點擊 “查看”選“程序員”,就可以方便的進行各進制的轉換了(如:你要轉換10進制90000000爲16進制,點“十進制”,輸入90000000,再點一下“16進制”,就會看到55D4A80,轉換就完成了。其他同理)。

這樣就可以很方便的在public.xml文件裏找到對應的資源文件或ID等。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章