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

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

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

@echo offif 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…

选择工程目录

接着一路Next…

2.工程创建成功后,在src目录上右键并选择”Mark Directory As——Sources Root”。

开始调试app

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

2.Run/Debug Configurations
创建一个”Remote” debug configuration (Run->Edit Configurations), 设置Port为8700。

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

4.运行应用,并在DDMS中选中该应用的进程。

5.点击Debug按钮,开始调试。当运行到断点时应用就会被暂停,这时就可以像平时调试应用一样操作了。

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

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

更多相关文章

  1. Android(安卓)Studio配置SVN
  2. Android基础入门教程——2.2.1 LinearLayout(线性布局)
  3. android工程在eclipse中报错解决办法
  4. Android(安卓)应用性能调试
  5. Android(安卓)之 自动提示功能(AutoCompleteTextView)的使用
  6. android多媒体播放源码解析
  7. Unity3D在android下调试
  8. Android(安卓)OpenGL学习笔记(二)之----三角形的绘制.
  9. Android中打开新的Activity的三种方法

随机推荐

  1. MIPI-DSI转HDMI
  2. 漫谈Android网络编程
  3. Android(安卓)点击通知栏消息 跳转到指定
  4. Android:Android(安卓)6.0+权限适配--简单
  5. Android开发规范之编码规范
  6. Android(安卓)WebView使用
  7. [摘]Android移动开发
  8. Android中ExpandableListView的实现
  9. 导入开源库到基于Android(安卓)Studio构
  10. Android添加全屏启动画面