本文首发于:行者AI
当我们想要了解一款APP时,最好的学习方式就是将其APK文件进行反编译。将APK进行反编译之后,我们就可以看到开发这个应用使用的资源文件(图片)、layout、样式、相关的实现代码等,学习这些资源文件才有助于开发技术的提升。
本文主要是介绍APK反编译的方法,希望能够帮助到大家。
1. 工具准备
1.1 工具介绍
- apktool:资源文件获取,可以提取出图片文件和布局文件进行使用查看。
- dex2jar:将APK反编译成Java源码(classes.dex转化成jar文件)。
- jd-gui:查看APK中classes.dex转化成出的jar文件,即源码文件 下载apktool、dex2jar、jd-gui,完成后将三个文件放在同一文件中,并解压dex2jar、jd-gui压缩包,这一步是为了方便进行反编译。
1.2 配置环境变量
oracle官网下载最新的jdk,并配置环境变量。
图1. 配置环境变量
2. APK反编译过程
2.1 执行APK反编译
(1)为了方便流程,我们将下载的apktool、dex2jar、jd-gui及需要反编译的APK文件都放在同一个文件夹下面。
图2. 文件夹界面
(2)打开cmd命令行,进入存放了APK文件的文件夹,运行apktool_2.5.0.jar这个jar文件来将APK文件进行反编译。命令如下: java -jar jar包名.jar
(3)下面这一句是我运行时所用的命令:
java -jar apktool_2.5.0.jar d -f C:UserslyDesktopchaibaofanbianyibao.apk -o 123
(4)这个命令的意思是启动apktool_2.5.0.jar将位于“C:UserslyDesktopchaibao”目录下的“fanbianyibao.apk”这个APK文件反编译,然后将反编译生成的文件存放到“C:UserslyDesktopchaibao123”文件夹中。
图3. 命令提示符界面
(5)反编译成功后,指定的文件目录下,会新增一个名叫“123”的文件夹。
图4. 指定文件界面
(6)打开“123”文件夹,就可以看到反编译后生成的文件,在这些生成的文件和文件夹当中,我们关心的是res文件夹中和AndroidManifest.xml文件,打开res文件夹,里面存放了我们所关心的xml文件,如下图所示:
图5. 新增文件夹列表
图6. 新增文件夹下res文件夹列表
APK资源文件介绍
上图中展示了APK文件反编译后的资源文件,下面对这些文件做一个简单的介绍:
- META-INF:保存APP的签名信息。
- classes.dex:.dex是Dalvik虚拟机上的可执行文件,需要使用dex2jar将其转换为jar文件。
- AndroidManifest.xml:Android清单文件,向Android系统提供应用的必要信息。
- assets:存放一些资源文件字体,声音等。
- lib:存放第三方库。
- original:存放未经过反编译的等AndroidManifest.xml文件。
- res:存放资源文件,例如图片、颜色、字符等。
- smali:存放Java编译成的smali代码,smali相当于Android虚拟机上运行的语言。
2.2 使用dex2jar反编译APK得到Java源代码
(1)将要反编译的APK后缀名改为 .rar或者 .zip,并解压,得到其中的classes.dex文件(它就是java文件编译再通过dx工具打包而成的),如图所示:
图7. 修改文件夹后缀并解压
(2)将获取到的classes.dex放到之前解压出来的工具“dex2jar-2.0”文件夹内,如图所示:
图8. 移动classes.dex
(3)在命令行下定位到dex2jar.bat所在目录,执行d2j-dex2jar classes.dex命令,将classes.dex反编译成jar包。
图9. 执行命令行
(4)反编译classes.dex得到classes-dex2jar.jar文件之后,就可以使用jd-gui工具将class文件反编译成Java源代码了。
图10. 文件列表展示
(5)启动jd-gui工具,选择File-OpenFile,选中classes-dex2jar.jar,这样就可以查看源代码了。
图11. 启动 jd-gui工具
图12. 源代码展示
3. 总结
在使用apktool反编译过程中如果出现了报错,很大可能是apktool的版本太低了,建议下载最新版本后再试试。但也请不要随便反编译开发人员的APK,尊重别人的劳动成果!
PS:更多技术干货,快关注【公众号 | xingzhe_ai】,与行者一起讨论吧!