Android反编译基本知识

1、用AXMLPrinter2反编译xxx.xml文件

Android的安装包是apk格式的文件。我们将其后缀名apk改为zip,就可以看到安装包中的内容。这里以QQ的Apk为例,我们可以看到它的压缩包里面由如下内容:

Android反编译基本知识_第1张图片
里面有很多XML文件打开后是乱码,AndroidManifest.xml也是如此,那是因为打包的时候对XML文件进行了压缩,所以看到的往往是全角的字符和乱码,不便于查找到我们想要看的内容。
AXMLPrinter2.jar,它可以将apk中已经处理过的XML还原为可读格式。

java -jar AXMLPrinter2.jar AndroidManifest.xml > AndroidManifest2.xml

2、用baksmali反编译xxx.dex文件

将上面解压得到的dex文件使用如下命令

java -jar baksmali-2.0.3.jar -o classout/ classes.dex

执行完成之后,在classout文件夹中就可以看到很多的smali文件。

同理,我们也可以使用smali编译classout成classes.dex,命令如下:

java -jar smali-2.0.3.jar classout/ -o classes.dex

3、使用 dex2jar 把classes.dex转换成jar

./dex2jar classes.dex

4、使用jd-gui 打开这个jar
Android反编译基本知识_第2张图片

5、APKTool的使用

1.decode
该命令用于进行反编译apk文件,一般用法为

apktool d <file.apk> <dir>

<file.apk>代表了要反编译的apk文件的路径,最好写绝对路径
<dir>代表了反编译后的文件的存储位置

2.build
该命令用于编译修改好的文件,一般用法为

apktool b <dir>

你可能感兴趣的:(Android反编译基本知识)