android apk 反编译过程

一、准备必要的工具

  apktool (资源文件获取)

  dex2jar(源码文件获取)

  jd-gui  (源码查看)

  以上三个文件的下载地址为:https://download.csdn.net/download/wyydn_8476/10811892

二、APK反编译流程

将【dex2jar-2.0.zip】和【jd-gui-windows-1.3.0.zip】分别解压到当前文件夹,如下图所示:

android apk 反编译过程

使用apktool反编译apk得到图片、XML配置、语言资源等文件

进入CMD命令行,切换到上述的3个工具的所在目录,如:E:\AndroidDevelopTool\,接下来我们要做的就是运行apktool_2.0.1.jar这个jar文件来将apk文件进行反编译,在java中,运行可执行jar包的命令是:

java -jar jar包名.jar

使用如下的命令运行apktool_2.0.1.jar反编译APK文件

java -jar apktool_2.0.1.jar d -f E:\AndroidDevelopTool\Test.apk -o MMTS

反编译成功后,会在当前目录(E:\AndroidDevelopTool\)下生成一个MMTS文件夹,打开MMTS里面就有反编译后生成的文件,打开MMTS文件夹,就可以看到反编译后的生成的文件,如下图所示:

android apk 反编译过程

生成的文件和文件夹当中,我们关心的是【res】文件夹中和AndroidManifest.xml文件,打开res文件夹,里面就有我们想要看到的东西了。

想查看哪个xml文件就使用文本编辑器打开看看吧,反正全部都可以看到了。以上就是使用apktool这个工具将一个apk反编译得到图片、XML配置、语言资源等文件的过程。

三、使用dex2jar反编译apk得到Java源代码

将要反编译的APK后缀名改为.rar或者 .zip,并解压,得到其中的classes.dex文件(它就是java文件编译再通过dx工具打包而成的),将获取到的classes.dex放到之前解压出来的工具【dex2jar-2.0】文件夹内,如下图所示:

android apk 反编译过程

在命令行下定位到dex2jar.bat所在目录,输入"d2j-dex2jar classes.dex",效果如下:

android apk 反编译过程

命令执行完成之后,在当前目录下就可以看到生成的Jar文件了,如下图所示:

android apk 反编译过程

反编译classes.dex得到classes-dex2jar.jar文件之后,就可以使用【jd-gui】工具将class文件反编译成java源代码了

android apk 反编译过程

使用jd-gui打开classes-dex2jar.jar就可以看到源代码了,如下图所示:

android apk 反编译过程

JD-GUI虽然可以将class反编译成java源代码,但是对于一些被混淆过的class,反编译的效果就不是那么理想了,被混淆过的class反编译后的效果图(类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名):

android apk 反编译过程

上一篇:[置顶] 浅谈Android的资源编译过程


下一篇:Android 8.0编译过程