APK反编译技巧

一、准备必要工具

反编译的前提 首先要配置jdk 环境变量  否则无法编译   如果已经配置好环境了可以忽略配置流程 直接到 下面1.1使用工具开始。

环境配置流程:

在桌面上 右击“我的电脑”,选择“属性”--选择“高级系统设置”--选择“环境变量”--选择“新建”

APK反编译技巧_第1张图片

点击新建后,就会出现这个,变量名为“JAVA_HOME”(复制我引号内的内容就可以了,不含引号,下同),变量值,必须是自己装jdk时的路径,比如我的安装路径是E:java\jdk\,路径问题也需要注意


APK反编译技巧_第2张图片

接下来找到“CLASSPATH”,没有的话就“新建

APK反编译技巧_第3张图片

变量名为“CLASSPATH”变量值“.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;”

APK反编译技巧_第4张图片

找到Path,对其进行编辑,在其原有变量值前加上“;%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;”,加的方法就是这样的C:变量值


APK反编译技巧_第5张图片

记得完成后要点两个确定


APK反编译技巧_第6张图片


APK反编译技巧_第7张图片

最后,就是测试自己配置是否成功了,同时按  R+ WIN(那个windows标志的键),输入cmd

进入命令提示符,输入JAVA,点击“Enter”,出来这些中文,就行了


APK反编译技巧_第8张图片

win10的java环境就配置好了。

1.1、使用工具

1.apktool (资源文件获取)

2.dex2jar(源码文件获取)

3.jd-gui  (源码查看)

1.2、工具介绍

apktool 

作用:资源文件获取,可以提取出图片文件和布局文件进行使用查看

dex2jar

作用:将apk反编译成java源码(classes.dex转化成jar文件)

jd-gui

作用:查看APK中classes.dex转化成出的jar文件,即源码文件

1.3工具下载

apktool下载地址:https://bitbucket.org/iBotPeaches/apktool/downloads


APK反编译技巧_第9张图片

下载好之后得到一个如下图所示的jar文件



dex2jar下载地址:http://sourceforge.net/projects/dex2jar/files/


APK反编译技巧_第10张图片


APK反编译技巧_第11张图片

下载完成之后,得到一个如下图所示的压缩包


APK反编译技巧_第12张图片

jd-gui下载地址:http://jd.benow.ca/


APK反编译技巧_第13张图片

下载完成之后,得到一个如下图所示的压缩包:


APK反编译技巧_第14张图片

 到此,需要使用到的3个相关工具都下载好了,在这里说明一下jd-gui的下载,我从官方网站上点击

下载时会经常出现如下图所示的问题


APK反编译技巧_第15张图片

但是多试几次又可以下载了,所以如果有遇到这个问题的朋友们不妨多试几次,或者从别的地方下载jd-gui,jd-gui算是做Java开发的一个必备工具了,用它来将class反编译成java源代码是非常方便的,网上搜索一下一般都可以下载到,只不过版本不一定是最新的。

二、Apk反编译流程

为了方便进行反编译,我们将上述下载好的3个工具统一放到一个文件夹中,例如:


APK反编译技巧_第16张图片

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


APK反编译技巧_第17张图片

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


APK反编译技巧_第18张图片

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

进入CMD命令行,如下:


APK反编译技巧_第19张图片

切换到上述的3个工具的所在目录,如:E:\AndroidDevelopTool\Android反编译工具包


APK反编译技巧_第20张图片

接下来我们要做的就是运行apktool_2.0.1.jar这个jar文件来将apk文件进行反编译,在java中,运行可执行jar包的命令是:

java -jar jar包名.jar

  使用如下的命令运行apktool_2.0.1.jar反编译MMTS-release-1.0.2.apk

java -jar apktool_2.0.1.jar d -f E:\AndroidDevelopTool\Android反编译工具包\测试apk\MMTS-release-1.0.2.apk -o MMTS

  这个命令是启动apktool_2.0.1.jar将位于【E:\AndroidDevelopTool\Android反编译工具包\测试apk\】目录下的"MMTS-release-1.0.2.apk"这个apk反编译,然后将反编译生成的文件存放到当前目录(apktool_2.0.1.jar所在的目录,也就是"E:\AndroidDevelopTool\Android反编译工具包"目录)下的一个【MMTS】文件夹中。这个文件夹的名字是可以随便取的,喜欢叫啥都行。

  执行反编译操作:


APK反编译技巧_第21张图片

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


APK反编译技巧_第22张图片

打开MMTS文件夹,就可以看到反编译后的生成的文件,如下图所示:


APK反编译技巧_第23张图片


APK反编译技巧_第24张图片

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


APK反编译技巧_第25张图片


APK反编译技巧_第26张图片


APK反编译技巧_第27张图片


APK反编译技巧_第28张图片

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

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

  将要反编译的APK后缀名改为.rar或者 .zip,并解压,得到其中的classes.dex文件(它就是java文件编译再通过dx工具打包而成的),如下图所示:


APK反编译技巧_第29张图片

将获取到的classes.dex放到之前解压出来的工具【dex2jar-2.0】文件夹内,如下图所示:


APK反编译技巧_第30张图片

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


APK反编译技巧_第31张图片

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


APK反编译技巧_第32张图片

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


APK反编译技巧_第33张图片

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


APK反编译技巧_第34张图片

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


APK反编译技巧_第35张图片

以上步骤是我亲自实践过之后一步步整理出来的,对照着做应该不会有太大问题。

三、Apk反编译注意问题

3.1、apktool版本太旧导致反编译失败的问题

  之前用过了apktool这个工具的一些旧版本,发现总是反编译不成功,在执行反编译时会出现如下错误:

  Exception in thread "main" brut.androlib.AndrolibException: Could not decode arsc file

APK反编译技巧_第36张图片

这个问题是因为apktool版本过低导致,而解决这个问题的办法就是使用最新版本的apktool就可以了,最新版本的下载地址:https://bitbucket.org/iBotPeaches/apktool/downloads

3.2、apktool执行反编译命令出现”Input file was not found or was not readable"的问题

这个问题是因为apktool升级到2.0以上时,使用方式已经替换,格式为:apktool d [-s] -f -o

好了,关于反编译apk的内容就这么多了。

最后,给大家分享我下载好的那三个相关工具,下载地址:http://pan.baidu.com/s/1jGKSQyU

你可能感兴趣的:(APK反编译技巧)