參考博客:
http://blog.csdn.net/ithomer/article/details/6727581
一、反編譯Apk得到Java源代碼
首先要下載兩個工具:dex2jar和JD-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.exe,apktool.bat,apktool.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等。