APK反编译
反编译介绍
我们知道,Android应用开发完成之后,我们最终都会将应用打包成一个apk文件,然后让用户通过手机或者平板电脑下载下来进行安装。正常情况下,Android应用打包成apk之后,就无法再看到开发这个应用时使用的资源文件以及代码了。但是我们通过网上提供了一些工具,还是可以将apk进行反编译的,apk反编译之后,我们就可以看到开发这个应用使用的资源文件(图片)、layout、样式、相关的实现代码等,apk反编译也算是Android开发中一个比较实用的技巧吧,当我们对别人开发好的应用感兴趣时,我们就可以通过这种技术手段将别人打包好的apk进行反编译,继而可以看到我们感兴趣的内容
使用工具
apktool
作用:资源文件获取,可以提取出图片文件和布局文件进行使用查看
dex2jar
作用:将apk反编译成java源码(classes.dex转化成jar文件)
jd-gui
作用:查看APK中classes.dex转化成出的jar文件,即源码文件
工具下载
- apktool下载地址:https://bitbucket.org/iBotPeaches/apktool/downloads
- dex2jar下载地址:http://sourceforge.net/projects/dex2jar/files/
- jd-gui下载地址:http://jd.benow.ca/
下载好后得到的文件:
反编译流程
为了方便进行反编译,我们将上述下载好的3个工具统一放到一个文件夹中
使用apktool反编译apk得到图片、XML配置、语言资源等文件
使用CMD进入该文件目录:java -jar apktool_2.3.1.jar d -f ./test.apk -o test
然后会得到这些内容:
res的里面为apk里面的xml以及图片等资源使用dex2jar反编译apk得到Java源代码
将要反编译的APK后缀名改为.rar或者 .zip,并解压,得到其中的classes.dex文件
然后将获取到的classes.dex放到之前解压出来的工具【dex2jar-2.0】文件夹内,并进入该目录,执行:
d2j-dex2jar classes.dex
命令执行完成之后,在当前目录下就可以看到生成的jar文件了
反编译classes.dex得到classes-dex2jar.jar文件之后,就可以使用【jd-gui】工具将class文件反编译成java源代码了,将jar文件用jd-gui工具打开即可看到其中的java源代码了。
jd-gui虽然可以将class反编译成java源代码,但是对于一些被混淆过的class,反编译的效果就不是那么理想了,被混淆过的class反编译后的效果图(类文件名称以及里面的方法名称都会以a,b,c….之类的样式命名)