一、目标
使用ida来动态调试so,这里我们以 AndroidNativeEmu使用指南 里面创建的libnative-lib.so为例
二、步骤
- 首先在ida的安装目录下找到对应的 android_server 文件,如果手机是64位的就使用 android_server64 (我的系统在/Applications/IDA Pro 7.0/ida.app/Contents/MacOS/dbgsrv: 目录下),拷贝到手机 /data/local/tmp 目录下面
adb push android_server /data/local/tmp
- 修改文件属性为可执行
adb shell
su
cd /data/local/tmp
chmod 777 android_server
./android_server
- 在Mac系统下映射android_server的调试端口23946
adb forward tcp:23946 tcp:23946
./fenfeiida -p23333
- 从手机中启动mysdk,然后在电脑上启动ida,选择 Android debugger
data:image/s3,"s3://crabby-images/6279d/6279da406aec79c80143352657513704cafb2679" alt="idastart"
- 在 Process options 中配置好上一步设置好的调试端口 23333
data:image/s3,"s3://crabby-images/cb23e/cb23e06a82f89be9047b079ab7e3b827bf7ab6e6" alt="idadbg1"
- 然后 Attach to Process,从弹出的窗口中选择 com.fenfei.myndk
data:image/s3,"s3://crabby-images/cf45b/cf45b8c7ab0cce43082a22aa9e02b019dd4c9def" alt="idadbg2"
- 双击之后就开始调试 com.fenfei.myndk进程了,从模块窗口中选择我们要调试的 libnative-lib.so
data:image/s3,"s3://crabby-images/9205b/9205bd4e91029957370076a0e59163c9a745e179" alt="idadbg3"
- 双击so之后就会显示这个so所有的导出函数,在要调试的函数F2下断点
data:image/s3,"s3://crabby-images/c73ab/c73ab73f78503b356d13c669742c29f08de37121" alt="idadbg4"
- F9 继续运行程序,就可以断在我们下的断点处了
data:image/s3,"s3://crabby-images/6ac1a/6ac1a637f829bb2db73e1ff1f95aec6e7990f88f" alt="idadbg5"
三、总结
ida除了静态分析二进制文件之外,在动态调试方面也是有一定的优势的。
data:image/s3,"s3://crabby-images/11ddc/11ddcbff3cde20ba7b92be4afa4239ff57327f62" alt="100"
关注微信公众号,最新技术干货实时推送
data:image/s3,"s3://crabby-images/84dca/84dca85a1c187191989445874a66382821b72d60" alt="100"