apk包的破解與反編譯

原文:http://www.jianshu.com/p/78cac8e9ddf1


關於apk包的破解,首先需要下載這三個反編譯的工具:

1. 提取資源:apktool, http://ibotpeaches.github.io/Apktool/install/
2. 反編譯:dex2jar, https://github.com/pxb1988/dex2jar
3. 查看源碼工具:jd-gui, http://jd.benow.ca/

這裏以開源中國的android版本爲例,看下怎麼進行破解和反編譯apk。

apktool

apk-tool是apk反編譯的神器,用來提取apk內的資源。
下載apk-tool之後會得到一個jar包,運行:

java -jar apktool_2.1.0.jar decode oschina/osc-android-app-2.4.apk

I: Using Apktool 2.1.0 on osc-android-app-2.4.apk
I: Loading resource table...
I: Decoding AndroidManifest.xml with resources...
I: Loading resource table from file: /Users/jjz/Library/apktool/framework/1.apk
I: Regular manifest package...
I: Decoding file-resources...
I: Decoding values */* XMLs...
I: Baksmaling classes.dex...
I: Copying assets and libs...
I: Copying unknown files...
I: Copying original files...

提取資源成功:


提取資源

這裏有一個smali目錄,它對應的是原始Android項目的src目錄,就是Java的源代碼。smaliDalvik虛擬機指令語言,可以在https://github.com/JesusFreke/smali 這裏查看smali的更多內容。

dex2jar

dex2jar是一個能操作Android的delvik(.dex)文件格式和Java的(.class)的工具集合。主要功能有:

1. d2j-dex2jar:執行dex到class的轉換
2. dex-reader-2.0/dex-writer-2.0:用於讀寫dex文件。
3. smali/baksmali:smali工具

這裏使用dex2jar主要是將apk的.dex反編譯成java源碼,方便閱讀。
首先將apk文件改名爲.zip文件。
解壓zip包,可以看到一個classes.dex文件,這個就是java文件編譯再通過dx工具打包而成的。
dex2jar目錄下:

./d2j-dex2jar.sh ../oschina/osc-android-app-2.4/classes.dex

得到文件classes-dex2jar.jar,得到的這個.jar文件可以使用jd-gui打開閱讀代碼。

jd-gui

jd-gui是java的反編譯器Java Decompiler project,把二進制的可執行文件翻譯成代碼。
jd-gui提供了一個圖形化的界面:


jd-gui

可以通過jd-gui直接打開上面得到的文件classes-dex2jar.jar瀏覽代碼:


閱讀代碼

這樣就得到apk的資源文件,也可以直接閱讀apk內的源代碼了。



文/姜家志(簡書作者)
原文鏈接:http://www.jianshu.com/p/78cac8e9ddf1
著作權歸作者所有,轉載請聯繫作者獲得授權,並標註“簡書作者”。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章