本帖最后由 蜗牛杰 于 2023-10-28 10:52 编辑
ida调试安卓so ####环境及工具 * IDA_Pro_7.7 * window10 * 真机Pexel XL(root) * 系统andrioid9 * Andrioid Device Monitor(非必须) ####准备工作 1、ida安装目录下的dbgsrv/android_server64 data:image/s3,"s3://crabby-images/2c380/2c380edccccd0c0c262e030084cd6ff39f2121e7" alt=""
执行命令将调试服务放入安卓机器 打开cmd到当前目录 `1、adb push andrioid_server64 /data/local/tmp/as ` 将服务push入安卓机器中并且改名为as `2、adb shell` 进入安卓命令行 `3、su` 切换root权限 `4、cd /data/local/tmp` 进入目录 `5、chmod 777 andrioid_server64` 修改andrioid_server64权限 `6、./andrioid_server64 -p12345` 启动服务 -p为启动端口参数可以不加 不加默认就是23946端口 data:image/s3,"s3://crabby-images/cb0f1/cb0f1bd9a018832529fb5adf567926766be0d214" alt=""
`7、adb forward tcp:12345 tcp:12345` 打开新的cmd 转发端口 data:image/s3,"s3://crabby-images/7a670/7a67037346e79b8f9fac7bd33933e89ef9599a44" alt=""
2、启动ida及其他设置 data:image/s3,"s3://crabby-images/5b0b8/5b0b875eec528564d6bb77872b7f4205d0cefa57" alt=""
我这里是64位的所以启动ida64.exe data:image/s3,"s3://crabby-images/e65d7/e65d7bcea76cc268c4443577efadd075c5c85d4b" alt=""
打开需要调试的so data:image/s3,"s3://crabby-images/b3738/b3738b9f5ab143410a35fca084c9721e4b15e75c" alt=""
点exports找到需要调试的代码 data:image/s3,"s3://crabby-images/bca0e/bca0e320790816999eec4e93b053e902782532a3" alt=""
我这里是demo所以就在导出函数里面 data:image/s3,"s3://crabby-images/9bc55/9bc55ac5cf0b6ba3939f04a6ff4e4fb0c27df51d" alt=""
双击进入汇编 data:image/s3,"s3://crabby-images/3757f/3757fba7be4ab4974bfa412d32b3ecfcea5e95ea" alt=""
tab进入伪C代码 data:image/s3,"s3://crabby-images/6bbcf/6bbcf3653628c2e7b41d2b35d4f4c683dc893ad1" alt=""
f2打上需要调试的代码debugger data:image/s3,"s3://crabby-images/44a1a/44a1a017cb1401a0d52dd4f32e9669aaaaf48752" alt=""
真机调试模式选择这个 data:image/s3,"s3://crabby-images/8a845/8a84547037bda4de52cfade4f7e0f4d68f6ad638" alt=""
简单调试点击这个就好了 不要点击倒数第二个在库加载/写在时挂起(`当时就是看了其他教程点击了这个 结果发现这个是库加载的时候就会挂起在断点上 导致迟迟debugger不到自己设置的点上--小白踩坑`) data:image/s3,"s3://crabby-images/49fc2/49fc2c151ecd5eff40a467a8d256eb0bbdc63600" alt=""
主机localhost/127.0.0.1都可以 端口就是刚刚转发出去的端口这里是12345 3、apk为设置为debugger模式 data:image/s3,"s3://crabby-images/b2efe/b2efe02a92341257e1ec4cf652e310cead1b487e" alt=""
`adb shell am start -n "com.example.myapplication/com.example.myapplication.MainActivity" -D` 这里 ""里面的是apk的入口 data:image/s3,"s3://crabby-images/f6a8a/f6a8a5826e74e2bb5ef97ff02329d5521cfa8d2f" alt=""
data:image/s3,"s3://crabby-images/2c35f/2c35f7a2cd861f55b68fdc8d05643b3d8a18e7d8" alt=""
附加到进程 data:image/s3,"s3://crabby-images/7bd2f/7bd2f894f96beb96456722b7c23434553c41826b" alt=""
选择要调试的进程 这里可以用ctrl+f搜索 data:image/s3,"s3://crabby-images/dcf0d/dcf0d91f40cfb9b56b8142e2e4c775257868a8a9" alt=""
加载完对应东西后会在这里断住 data:image/s3,"s3://crabby-images/e43bf/e43bfe28481f77b8050d682ae3f156867752e73b" alt=""
打开Andrioid Device Monitor 我这里安卓了andrioid SDK 所以 对应的tools/lib下有对应的monitor 这里有一个坑 就是 这个monitor 只有安装了JDK1.8才可以打开 其他版本会报错 `jdb -connect com.sun.jdi.SocketAttach:port=8700,hostname=localhost` 执行命令 data:image/s3,"s3://crabby-images/9e901/9e901b348185dea26a46457542cb41a9060a9d53" alt=""
等待初始化就可以了 data:image/s3,"s3://crabby-images/0fba9/0fba9ab4034d3a69939e578ad6112db8176bcd1e" alt=""
data:image/s3,"s3://crabby-images/6aa05/6aa059bc45d906112ea4f0e179ae4304d719872c" alt=""
这样就可以了 已经进入打的断点里面了 #####这里最需要注意的就是 data:image/s3,"s3://crabby-images/1f0fa/1f0fa0727a90b62fea0ba4e61aa0cc7c50871495" alt=""
选项 新手应该是暂时不需要的 这里是库加载的时候就会挂起/卸载断点 新手第一次调试不用勾选这个 data:image/s3,"s3://crabby-images/7e229/7e229173da8a85a1131748164b44eb163cea4873" alt=""
data:image/s3,"s3://crabby-images/aa92b/aa92b4ade37826647383a30d87425bcc93fc7fd8" alt=""
注:若转载请注明大神论坛来源(本贴地址)与作者信息。
|