Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程

smalidea

smalidea是一个IntelliJ IDEA/Android Studio smali语言插件,可实现动态调试smali代码。

github地址:https://github.com/JesusFreke/smali/wiki/smalidea

下载地址:https://bitbucket.org/JesusFreke/smali/downloads

动态调试安卓app

smalidea支持14.1或以上版本的IDEA。Android Studio如果是基于14.1或以上版本的IDEA也是支持的,我这里用的是2.0版本的Android Studio,IDEA的操作也差不多。

从上面的地址下载这3个文件。
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第1张图片

安装smalidea

1.打开Android Studio,按Alt+Ctrl+S打开设置界面,点击Plugins——Install plugin from disk…——选择下载好的smalidea-0.03.zip。
2.重启Android Studio。

baksmali

使用baksmali反编译apk得到smali代码。

使用下面命令得到apk的smali代码,在./projects/myapp/src目录下
java -jar baksmali-2.1.2.jar myapp.apk -o ./projects/myapp/src

Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第2张图片

下面是一个windows下批处理的代码,用于更新src目录下smali代码,copy到baksmali-2.1.2.jar同级目录下

@echo off

if exist projects\myapp\src @DEL /S /Q projects\myapp\src\* 

java -jar baksmali-2.1.2.jar myapp.apk -o ./projects/myapp/src

创建新的工程并导入smali

1.Project from Existing Sources…
这里写图片描述

选择工程目录
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第3张图片

接着一路Next…
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第4张图片

2.工程创建成功后,在src目录上右键并选择”Mark Directory As——Sources Root”。
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第5张图片

开始调试app

1.打开DDMS
工程创建成功后,发现Android Device Monitor按钮不能点击,因为这不是一个完整的安卓工程,不过可以到Android SDK/tools目录下点击monitor.bat打开DDMS。
这里写图片描述

2.Run/Debug Configurations
创建一个”Remote” debug configuration (Run->Edit Configurations), 设置Port为8700。
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第6张图片

3.在smali代码中你需要的地方打上断点。

4.运行应用,并在DDMS中选中该应用的进程。
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第7张图片

5.点击Debug按钮,开始调试。当运行到断点时应用就会被暂停,这时就可以像平时调试应用一样操作了。
Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程_第8张图片

说明:在smali中所有的局部变量用v开头,方法的顶部.locals n表示这个方法使用n个局部变量。所有的参数用p开头,局部变量和参数都是从0开始编号。对于非静态方法来说,p0就是对象本身的引用,即this指针。

关于smali语法可以参考这篇文章

你可能感兴趣的:(动态调试,smali,android,Android)