动态调试smali代码学习记录
预备知识
DDMS
Dalvik Debug Monitor Serivce,Dalvik调试监控服务,为Android SDK提供的一款拥有监控Dalvik虚拟机的调试软件,启动文件位于<Andorid SDK>/tools/monitor.bat(低版本的SDK为ddms.bat)
adb forward命令
用于创建一个端口映射,将本地端口(PC端口)映射到远程端口(手机端口),例如:
|
adb forward tcp:8001 tcp:8002 |
之后PC端访问8001端口的数据包,会自动转发到手机的8002端口。
adb还提供了reverse命令,操作与forward相反,将远程端口(手机端口)映射到本地端口(PC端口),例如:
|
adb reverser tcp:8001 tcp:8002 |
之后手段端访问8001端口的数据包,会自动转发到电脑的8002端口。
其他带参命令可以参考adb的帮助文档:

JDWP
Java Debug Wire Protocol,Java调试线程协议,定义了调试器(debugger)和被调试的 Java 虚拟机(target vm)之间的通信协议。详细请参考:
https://www.ibm.com/developerworks/cn/java/j-lo-jpda3/
Dalvik虚拟机会启动一个JDWP线程,用于远程调试。远程调试器可以通过JDWP端口号,调试指定进程。每个可调试的进程的PID就是其JDWP的端口号。可以使用adb jdwp命令查看所有可以调试的进程PID(需要使用ctrl + c退出)。
动态调试Smali代码
参考作者的说明:
https://github.com/JesusFreke/smali/wiki/smalidea
本次调试在Windows 10 + AS 3.2.1下完成。
- 使用Baksmali或apktool反编译apk文件,得到Smali代码。如果需要重新打包apk,推荐使用apktool。以下默认采用apktool。
- 把反汇编结果,在AS中当成现有工程打开。工程目录如下:

- 将smail文件夹标记为"Source Root"

这里简单补充下,阅读代码的小技巧。
在.method字段,使用"Find Usage"功能,可以定位该方法的所有调用者。

在方法类型上,使用"Declaration",可以定位方法的定义处。

- 创建一个远程调试的配置:

点击"+",新建一个配置,选择"Remote"模板,配置名可以任意命名,这里取名为SmaliDebug。

端口号可以任意指定,只要不被其他进程占用,通常使用8700(DDMS使用的调试端口号)。

- 确认调试apk的AndroidManifest.xml文件中,<application>标签的android:debuggable属性为true:

如果没有,请自行补充,再使用apktool打包签名。
- 安装并启动应用,PC端使用adb jdwp命令查看目标进程的PID(最后一个),需要使用ctrl + c结束该命令。
之后使用以下命令,绑定远程调试端口:
|
adb forward tcp:8700 jdwp:<PID> |
TCP的端口号,是刚刚配置远程调试配置时填写的。<PID>是刚刚查询的结果。
或者通过以下命令,也可以获取调试进程的PID:
|
adb shell ps | findstr "<packageName>" |
<packageName>是apk的包名,命令结果的第二列就是进程的PID。

- 在目标代码下断点:

启动调试:

手机端操作app,触发断点:

之后调试步骤,与正常调试一样。
release编译的apk,抹除了参数名和局部变量名,需要手动添加watch变量,watch寄存器查看。
(应该是插件的bug,导致p寄存器(入参寄存器)值显示不正常)
- 如果调试过程中,修改了代码。需要使用apktool重新打包,重新安装。之后重复6步骤,开始调试。
- 调试结束后,建议使用adb forward --remove-all命令,清理端口绑定。
如果你在Linux调试,作者给出了一条命令,可以在启动app后,一步完成端口绑定:
|
adb forward tcp:8700 jdwp:$(timeout 0.5 adb jdwp | tail -n 1) |
解释下这条命令:
$()会执行括号内的命令,将命令的运行结果作为值。
timeout命令会执行一个子命令,如果子命令没有在规定时间内(这里是0.5秒)完成,直接杀死。
tail -n 1,输出输入内容的最后一行,这里通过管道,将jdwp作为输入。
合起来,"$(timeout 0.5 adb jdwp | tail -n 1)"就是adb jdwp输出的最后一行,并自动结束jdwp命令。
动态调试smali代码学习记录的更多相关文章
- 使用IDEA动态调试smali代码
原创,转载请注明出处. 一般java ide(如eclipse.idea)都可用来进行smali的动态调试,这里选择IDEA. 第1步:使用apktool反编译apk java -jar apktoo ...
- Android Studio动态调试smali代码
工具: Android Studio版本: 3.0.1 smalidea插件: https://github.com/JesusFreke/smali/wiki/smalidea. 反编译工具:本节先 ...
- 动态调试smali代码
Android Killer对应用进行反编译为smali代码,看看Manifest文件中application标签里面是否有android:debuggable="true",没有 ...
- Android studio动态调试smali
前面介绍了使用IDA动态调试smali,这种方法设置简单,不用重打包,用起来方便,但是如果变量类型设置错误则会马上退出调试,这是让人不爽的地方,而使用Android studio则不会. 0x01 ...
- Android调试系列—使用android studio调试smali代码
1.工具介绍 使用工具 android killer:用于反编译apk包,得到smali代码 android studio:调试smali代码工具,或者使用idea,android studio就是在 ...
- Netbeans 6.8 + apktool_2.0.0b9 动态调试smali文件
前言 很早就知道用Netbeans能够单步调试smali,一直拖到现在才真正的自己实现了一次~ 下面是详细步骤! 0×1 环境及工具 a.apktool_2.0.0b9 下载地址:http://con ...
- android动态调试samli代码(转)
转载自看雪http://bbs.pediy.com/showthread.php?t=189610,非常感谢原作者分享! 跟踪apk一般的做法是在反编译的smali代码中插入log输出,然后重新编译运 ...
- AndroidStudio+ideasmali动态调试smali汇编
0x00 前言 之前对于app反编译的smali汇编语言都是静态分析为主,加上一点ida6.6的动态调试,但是ida的调试smali真的像鸡肋一样,各种不爽,遇到混淆过的java代码就欲哭无泪了 ...
- Array方面Js底层代码学习记录
一..clear() →Array function clear() { this.length = 0; return this; } 返回清除item的空数组. 例子: var fruits = ...
随机推荐
- 同步与异步区别,Invoke与BeginInoke的区别
先说同步与异步的区别,总说同步异步的,其实一直不清楚什么是同步异步,今天找了一下: 同步:当一个消息发送后,等对方回应后继续发送下一条指令. 异步:当一个消息发送后,不等对方回应就发送下一条. 同步, ...
- 也谈在 .NET 平台上使用 Scala 语言(续)
而我是在 Ubuntu 操作系统中使用 Scala.NET 的,应该没有这个问题. 那么,就让我们来測试一下吧. 如今,我们添加一个 DotNet.cs 文件,例如以下所看到的: 1 2 3 4 5 ...
- EL 表达式 函数 操作 字符串
<%@tablib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %> ${fn ...
- Spring MVC中的模型数据处理
一.综述 Spring MVC 提供了以下途径来输出模型数据: 1.ModelAndView 当处理方法返回值类型为 ModelAndView时, 方法体即可通过该对象添加模型数据到请求域. 2.Ma ...
- 获取exe文件窗口抓图,将memo转化为JPG输出
unit Unit1; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System ...
- OpenCV编程->RGB直方图统计
我们在处理彩色图像时.特别是在做局部图像的阈值切割时,须要一个直观的RGB统计图. 接下来開始实现. 代码: void CalcHistRGB() { IplImage* img_sou ...
- C#读取excel 找不到可安装的ISAM
实在没有办法了 就仔细的查看了 一下数据链接字符串: string strConn = "Provider=Microsoft.Jet.Oledb.4.0;Data Source=" ...
- lazyload.js参数说明
lazyload.js是jQuery的一个插件,可以用来实现图片异步加载. lazyload插件如何添加参数: $("img").lazyload({ //参数添加到此位置,建议一 ...
- mysql 中 all any some 用法
-- 建表语句 CREATE TABLE score( id INT PRIMARY KEY AUTO_INCREMENT, NAME ), SUBJECT ), score INT); -- 添加数 ...
- SpringBoot学习笔记(4):与前端交互的日期格式
SpringBoot学习笔记(4):与前端交互的日期格式 后端模型Date字段解析String 我们从前端传回来表单的数据,当涉及时间.日期等值时,后端的模型需将其转换为对应的Date类型等. 我们可 ...