Android的APK反编译有两种方法(其实就是一种),一种能得到Java文件(工程中的Java类),一种能得到资源文件(Xml文件及图片等)。
1 得到Java文件
需要两个工具:dex2jar和jg-gui
(1)将dex文件转换成jar文件
首先将把.apk文件改名为.zip,然后解压缩,得到其中的classes.dex文件,它就是java文件编译再通过dx工具打包成的,在命令行模式下定位到dex2jar.bat所在目录,
运行“dex2jar classes.dex”,得到classes.dex.dex2jar.jar
(2)显示jar文件的结构。
运行jg-gui.exe,打开得到的Jar文件,就可以看到apk源文件的层次结构了。
比如,下载个新浪微博的官方程序apk文件,用上面的步骤打开,会发现有很多$1,$2等的类名,反编译个自己编写的程序看看,发现有的也有$开头的类,仔细看看会发现每个$开头的文件都implements或extend一些接口或类,这些$开头的文件是同名的不带$的文件的匿名内部类。比如Handler类,Thread类,OnClickListener接口等,经常使用匿名内部类。
2 得到资源文件和xml文件
直接将.apk文件改成.zip文件得到的资源文件不是文本文件,使用apktool反编译可以得到资源文件和xml文件。需三个文件:apktool.jar和apktool.bat和aapt.exe,也是使用命令行到文件目录,使用参数d就能得到apk的工程目录,apktool d *.apk。
这样就可以得到任何程序的图片、布局文件了