- 负责破解apk,普通的修改apk为rar解包得出的xml等文件是加密的,用这个工具解包就可以查看并修改,
- 转成smali文件。smali是在dalvik虚拟机执行的核心代码,有自己的语法,java编译成smali,打包成dex在vm上执行
- 我们不能修改java代码,但可以直接修改smali代码,然后回编成dex,覆盖原来的dex,打包成apk,就实现了修改代码
- 百度网盘地址
语法:
cd apktool2.0.0
## 反编译
apktool d xxx.apk
## 回编译
apktool b xxx文件夹
- 如果想查看java代码,怎么办?
可以使用该工具的命令
d2j-dex2jar.bat
- dex文件怎么得来?
修改
xxx.apk
文件为xxx.rar
,直接解压缩,就可以获得classes.dex
文件 - 百度网盘地址
语法:
cd dex2jar-2.0
d2j-dex2jar.bat D:\Android\apk\Bmi\classes.dex
## 会在dex2jar-2.0目录获得classes.dex.dex2jar.jar文件
- 使用本工具查看上一步获得的classes.dex.dex2jar.jar文件,
就可以直接预览java源码了
如图:
- 百度网盘地址
- 比jd-gui-windows更方便
- 百度网盘地址
以上工具是apk反编译的基础操作,但是命令行操作起来比较繁琐,所以推荐一些高级工具,对上述的基础工具做了整合,极为便捷。
强烈推荐,工具整合的相当完善 百度云盘地址
APK反编译之一:基础知识--smali文件阅读:本篇文章结合一个activity.smali文件,来讲解smali的基础语法。
smali语法简析:更为详细的讲解
- 讲述v本地寄存器,p参数寄存器的区别
- Long和Double类型是64位的,需要2个寄存器
- 非静态参数寄存器,p0代指
this