Weilit / android-reverse

android逆向工程工具及使用教学(how to reverse apk?)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

基础工具使用说明

  • 负责破解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源码了 如图:
  • 百度网盘地址

高级工具

以上工具是apk反编译的基础操作,但是命令行操作起来比较繁琐,所以推荐一些高级工具,对上述的基础工具做了整合,极为便捷。

强烈推荐,工具整合的相当完善 百度云盘地址

基础知识

APK、Dalvik字节码和smali文件

APK反编译之一:基础知识--smali文件阅读:本篇文章结合一个activity.smali文件,来讲解smali的基础语法。

smali语法简析:更为详细的讲解

  • 讲述v本地寄存器,p参数寄存器的区别
  • Long和Double类型是64位的,需要2个寄存器
  • 非静态参数寄存器,p0代指this

About

android逆向工程工具及使用教学(how to reverse apk?)


Languages

Language:Shell 46.7%Language:Batchfile 45.5%Language:Smali 7.8%