处于学习和研究的目的,还有为了反破解和反逆向的目的,有时候须要破解apk,关于apk包的破解,须要使用三个反编译工具:javascript
这里以开源中国
的android版本为例,看下利用上面的三个工具如何进行破解和反编译apk。java
apk-tool
是apk反编译的神器,用来提取apk内的资源。
下载apk-tool以后会获得一个jar包,运行命令:android
java -jar apktool_2.1.0.jar decode oschina/osc-android-app-2.4.apkgit
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...复制代码
提取资源成功会获得下图中的结果:github
smali
目录,它对应的是原始Android项目的
src目录
,也就是Java的源代码。
smali是
Dalvik虚拟机指令语言,能够在
github.com/JesusFreke/… 这里查看smali的更多内容。固然
smali
语言并非咱们的最终目的,
Java
源代码才是。
dex2jar
是一个能操做Android的delvik(.dex)文件格式和Java的(.class)的工具集合。主要功能有:app
使用dex2jar
主要是将apk的.dex
反编译成java源码,方便阅读。
首先将apk文件更名为.zip文件
,而后解压zip包
,能够获得一个classes.dex
文件,这个就是java文件编译再经过dx工具
打包而成的二进制文件。
运行dex2jar
,反编译classes.dex
:工具
./d2j-dex2jar.sh ../oschina/osc-android-app-2.4/classes.dex学习
就能够获得文件classes-dex2jar.jar
,这个.jar
文件并无直接阅读,可是能够使用jd-gui
打开阅读代码。ui
jd-gui
是java的反编译器Java Decompiler project
,把二进制的可执行文件翻译成代码。jd-gui
提供了一个图形化的界面:
spa
能够经过jd-gui
直接打开上面获得的文件classes-dex2jar.jar
,而后就能够浏览代码了:
经过上面的步骤这样就获得apk的资源文件和源代码了,完成了apk的破解。