Android反编译基本知识

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

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

这里写图片描述
里面有很多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
这里写图片描述

5、APKTool的使用

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

apktool d <file.apk> <dir>

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

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

apktool b <dir>

参考文章:
浅谈Android应用保护(一):Android应用逆向的基本方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值