| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 移动开发 -> 使用lldb和hopper计算函数地址给运行中的app添加断点 -> 正文阅读 |
|
[移动开发]使用lldb和hopper计算函数地址给运行中的app添加断点 |
文章目录原理讲解
使用hopper找到你要下断点的macho-o文件里的函数地址的方法例如,我通过theos tweek已经在BaseMsgContentViewController控制器里,把所有的方法都添加了打印信息. 的TextDidChanged方法下hook了打印的方法 例如其中BaseMsgContentViewController这个文件是发送信息时候的控制器,里面每次文字改变会调用下面的方法,里面也添加了打印信息,如下面代码
通过控制台打印,可以看到当手机微信输入789的时候,函数被打印了如下图: 打开Hopper Disassembler,把脱壳以后的app的mach-o文件拖拽进去.
找到hopper搜搜到的函数地址 例如,上图,的函数地址:00000001034d0be8 通过越狱手机连接上mac,并且进入lldb具体操作参见这篇文章
mac端输入:
查看app所有段落和偏移量: -f是完整路径 -o是偏移量
打印结果如下:
找到上面第0行 wechat.app这行,这行开头的地址0x00000000025cc000 是这个app的偏移量
在lldb里通过计算后的内存地址设置断点例如这个函数下的断点的地址就是如下,注意添加0x开头,因为) image list -o -f 和hopper里复制的地址都是16进制的.用+加号相加
得到结果下断点成功
下面按下c,让app继续执行,相当于xcode的F9
之后我退出聊天页面再重新进入,再用键盘输入文字,发现lldb在断点停住了
代表你设置断点成功了,如下图 |
|
移动开发 最新文章 |
Vue3装载axios和element-ui |
android adb cmd |
【xcode】Xcode常用快捷键与技巧 |
Android开发中的线程池使用 |
Java 和 Android 的 Base64 |
Android 测试文字编码格式 |
微信小程序支付 |
安卓权限记录 |
知乎之自动养号 |
【Android Jetpack】DataStore |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 16:34:29- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |