标签:
工具名称、介绍及下载地址:
apktool(获取资源文件)
作用:获取资源文件,可以提取出图片文件和布局文件进行使用查看。
下载地址:
dex2jar(获取源码文件)
作用:将apk反编译成java源码(classes.dex转化成jar文件)。
下载地址:
jd-gui(查看源码)
作用:查看APK中classes.dex转化成出的jar文件,即源码文件
下载地址:
反编译流程:
一、apk反编译得到程序的源代码、图片、XML配置、语言资源等文件
下载上述工具中的apktool,解压得到3个文件:aapt,apktool,apktool.jar,如图:
将需要反编译的APK文件放到该目录下,
打开命令行界面(即终端),定位到apktool文件夹,输入以下命令:./apktool d -f demo.apk demo
注:./表示当前目录
(命令中demo.apk指的是要反编译的APK文件全名,demo为反编译后资源文件存放的目录名称,即为:./apktool d -f [apk文件 ] [输出文件夹])
反编译完成后,目录结构如下图:
说明获取成功,之后发现在文件夹下多了个demo文件夹,点击就可以查看该应用的所有资源文件了。
如果你想将反编译完的文件重新打包成apk,那你可以输入./apktool b demo(刚才编译出来文件夹)便可,效果如下:
之后在之前的demo文件下便可以发现多了2个文件夹:
build
dist(里面存放着打包出来的APK文件)
二、apk反编译得到Java源代码
下载上述工具中的dex2jar和jd-gui,解压。
将要反编译的apk后缀名改为.rar或则 .zip,并解压,得到其中的classes.dex文件(它就是java文件编译再通过dx工具打包而成的文件),如下图:
将获取到的classes.dex放到之前解压出来的工具dex2jar-0.0.9.15文件夹内,在命令行下定位到dex2jar.bat所在目录,输入dex2jar.bat classes.dex,效果如下:
在该目录下会生成一个classes_dex2jar.jar的文件,然后打开工具jd-gui文件夹里的jd-gui.dmg,之后用该工具打开之前生成的classes_dex2jar.jar文件,便可以看到源码了,效果如下:
被混淆过的效果图(类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名)。
通过反编译,可以获知该应用用到的第三方库文件,它的代码是如何编写的等等。然而,如果该APK进行了混淆处理,那么你看到的类文件名称以及里面的方法名称都会以a,b,c....之类的样式命名,所以你可以想找到你所想得知的界面代码可能会十分费劲,找到了代码可能看起来也会很费劲,可是一个大体的思路会获得,有了这个思路,你就可以自己去尝试了。
参考:
混淆的参考教程:Android如何防止apk程序被反编译
标签:
原文地址:http://blog.csdn.net/wwzqj/article/details/45285993