Android动态调试合集
文章目录
JEB动态调试smali
-
选中smali代码后,
Ctrl B
下断点 -
启动app
-
以debug模式启动Activity(调试一启动就执行的方法)
adb shell am start -D -n [package_name]/[activity_name]
-
调试可以手动触发(不着急)的方法,手动打开app或者去掉上述命令的
-D
参数
-
-
JEB附加进程
- 菜单栏【调试器】下选择【开始】(不能开启ddms或AndroidStudio)
- 弹出对话框,选择设备、进程后,点击【附上】。app会被附加,运行到断点断下。
使用AndroidStudio配合Smalidea插件来动态调试smali
- Smalidea安装
- github地址:JesusFreke/smalidea: smalidea is a smali language plugin for IntelliJ IDEA (github.com)
- 下载后在插件页导入安装即可
- 配置及使用:
- (0.6版本已可以自动配置)检查
Settings
->Editor
->File Types
中,除了Smali
外多了一个smali Files
,内有内容*.smali
- 菜单栏
File
下多了【Profile or Debug Apk】
;可以方便的选择一个apk来反编译成项目、或使用apktool d
反编译然后导入也可以
- (0.6版本已可以自动配置)检查
- 获得反编译apk后的smali文件夹
- 方法一:
apktool d
反编译apk得到文件夹 - 方法二:使用菜单栏
File
下的【Profile or Debug Apk】
- 方法一:
方法一:
-
AS准备调试
- 使用AndroidStudio选择**【Import Project(导入项目)】**,并选择该文件夹;会提示不是项目,然后选择创建新项目
- 添加运行配置
【Add Configuration...】
- 选择模板
【Remote JVM Debug】
,端口设置为8700
- 选择模板
- 设置反编译后文件夹的根目录,右键,
【Mark Directory as】
选择【Sources Root】
(貌似可选) - 在smali相应处下断点
-
开始调试
-
点击【运行】右侧的【调试】按钮,程序开始运行,运行到断点断下
-
左上角选择【停止】按钮左侧的【Attach Debugger to Android Process】附加按钮
-
以debug模式启动Activity(调试一启动就执行的方法)
adb shell am start -D -n [package_name]/[activity_name]
-
转发app运行端口到
8700
(可选)-
命令方式
adb forward tcp:8700 jdwp:[app_port]
-
使用ddms(monitor);位于
Sdk\tools\monitor.bat
(需下载)- 打开monitor,选中app包名所在进程,该进程的port后会出现
/8700
- 打开monitor,选中app包名所在进程,该进程的port后会出现
-
-
点击【附加】按钮选择设备下的进程,点击OK,即可开始调试
-
-
方法二:
可直接【运行】、【调试】、【附加】
IDA动态调试so
调试app一启动就执行的native函数
如JNI_OnLoad
、.init_proc
或.init_array
等
调试此类函数需要以debug模式启动app
-
启动
android_server
- 复制
IDA\dbgsrv\
下的对应的android_server
到手机的如/data/local/tmp/
目录下,并给予执行权限 - 在
su
下运行server启动监听
- 复制
-
开启端口转发(将设备与客户机间的23946端口连通
adb forward tcp:23946 tcp:23946
-
以debug模式启动Activity
adb shell am start -D -n [package_name]/[activity_name]
-
转发app运行端口到
8700
(可选,详见【步骤6】)-
命令方式
adb forward tcp:8700 jdwp:[app_port]
-
使用ddms(monitor);位于
Sdk\tools\monitor.bat
(需下载)- 打开monitor,选中app包名所在进程,该进程的port后会出现
/8700
- 打开monitor,选中app包名所在进程,该进程的port后会出现
-
-
IDA准备、附加进程
- IDA载入so,在native方法所需处下断点(可选)
- 配置调试器选项
- 选择调试器
[Remote ARM Linux/ Android debugger]
- 菜单栏
[Debugger]
下[Process options]
中,配置主机为localhost
或127.0.0.1
(即本机),端口为默认23946
(同server监听端口) - 菜单栏
[Debugger]
下[Debugger options]
中,可根据需要勾选Suspend on process entry point
,Suspend on thread start/exit
,Suspend on library load/unload
- 选择调试器
- 附加进程
- 选择菜单栏
[Debugger]
下[Attach to process]
,之后弹出一个可调试应用包名的窗口,ctrl F
可以搜索,选择调试的应用包名,点击OK
进行附加
- 选择菜单栏
-
jdwp
使app开始运行,此处的8700
为【步骤4】中转发端口(若未执行步骤4,可使用ddms的最后一列数字)jdb -connect com.sun.jdi.SocketAttach:hostname=localhost,port=8700
-
返回IDA,
-
寻找加载的so
-
如果在【步骤5.2.3】中勾选了中断设置,先查看
module
窗口(ctrl+s)是否加载了所需的so,如果没有、需要F9运行程序再次查看,如此反复(或者查看IDA是否弹出【same】对话框?)如果没有勾选,F9运行则会直接弹出same对话框(记得在【步骤5.1】下断点);确定后会卡住一段时间
-
加载时,IDA会询问远程的so文件与本地的是否相同,选择【same】(选择后,so文件就被加载进来了)
-
加载后,双击so的module,会弹出module方法窗口,选择相应的方法如
JNI_onLoad
,并在相应地址如函数开头下断点
-
-
当被调试so加载进来并且下好断点后,F9运行,即可断在
JNI_onLoad
开头处
-
-
完成,可以愉快的调试啦。记得根据需要取消【步骤5.2.3】,不然会一直断下
调试可以手动触发的函数
自然也可以按照上面那种方式,但是比较慢,因为app要加载
或者
- 【如上步骤1】
- 【如上步骤2】
- 手动启动app,或命令
adb shell am start -n [package_name]/[activity_name]
(即去掉-D
参数) - 【如上步骤5】,一般不需要【步骤5.2.3】(根据自己情况)
- 【步骤4】附加完成后,会弹出【same】窗口,之后点击运行、触发断点,即可开始调试
错误踩坑解决
Smalidea调试
【附加】时无设备或进程
没有设备进程供选择,点击菜单栏【File】的【Invalidate Caches / Restart…】来清理缓存并重新启动AS
此外
debuggable属性
app在清单中添加debuggable属性
在AndroidManifest.xml
的application
标签中添加android:debuggable="true"
修改设备的ro.debuggable=1
安装magisk后
magisk resetprop ro.debuggable 1
magisk resetprop ro.secure 0
magisk resetprop ro.adb.secure 0
重启设备后失效
magisk安装MagiskHide Props Config
模块
使用命令props
来修改(未测试)