Mac IDA动态调试Android应用so文件

使用环境:

macbookpro m1芯片(win试过未调试成功,具体原因未知。两者调试流程相同)

ida9.1

魅族root note9

应用:ollvm_ndk

调试流程:

1.手机上安装ollvm_ndk,并把其中的so文件放在电脑上

2.访达找到ida,右键显示包内容,搜索server,找到android_server和

android_x64_server,win找到配置ida的位置,也有这两个文件,不能通用。

3.把这两文件推送到手机上的/data/local/tmp(其他目录也一样),设置权限并执行./android_server,如果调试失败就执行64的

4.打开ida,放入之前获取的so文件,搜索java_xxxxxx,点击代码下一个断点。这里讲的是附加进程调试,启动新进程调试比较复杂(我还不会🙅🏻‍♀️)

5.点击debugger > select.... >remote arm linux/android debugger。

运行命令adb forward tcp:23946 tcp:23946进行端口转发

点击debugger >process options... > hostname填入127.0.0.1即可

点击debugger>attach to process.. >(手机上打开应用)点击serarch>搜索kanxue并点击这个进程


6.之后会弹出一个框,显示两个so文件是否相同,点击same即可。

7.在手机上的应用点击一下,即可进入之前断点的位置。

设置硬件断点

平常断点的原理就是把原来的代码修改成断点代码,如果一些自解密代码修改成debugger修改成断点就会变成一个错误的结果。

硬件断点不会修改内存数据

相关推荐
webkubor18 小时前
Hermes 在 macOS 上反复要文档授权,真正的问题不是 AI,是启动方式
macos
西西学代码1 天前
BluetoothDevice
macos·objective-c·cocoa
一块小土坷垃1 天前
BuhoCleaner 1.15.6 深度体验:macOS 系统清理与卸载优化工具评测
macos·开源软件
Youyzq1 天前
安装龙虾流程mac
macos·openclaw
ACGkaka_1 天前
JDK 版本管理工具介绍:jenv与sdkman(Mac端)
java·macos·sdkman
库奇噜啦呼1 天前
【iOS】 Blocks
macos·ios·cocoa
一块小土坷垃1 天前
Pearcleaner:一款功能强大的免费开源 macOS 应用清理工具
macos·开源软件
承渊政道1 天前
【递归、搜索与回溯算法】(递归问题拆解与经典模型实战大秘笈)
数据结构·c++·学习·算法·macos·dfs·bfs
中国胖子风清扬1 天前
基于GPUI框架构建现代化待办事项应用:从架构设计到业务落地
java·spring boot·macos·小程序·rust·uni-app·web app
yuanzhengme2 天前
AI【应用 04】FunASR离线文件转写服务开发指南(实践篇)
人工智能·macos·xcode