几种Dalvik Hook方案研究
来源:互联网 发布:vb中elseif什么意思 编辑:程序博客网 时间:2024/06/06 07:39
Dalvik Hook的基本原理
如上一篇文章所述,每个java方法在虚拟机内部都对应一个Method结构体(可以将JNI的jmethodID强转为指向此Method结构体首地址的指针得到),Dalvik Hook通常通过修改Method结构体内容实现.常见的两种hook思路:
- 将被hook方法Method结构体的accessFlags置native标志位,并将nativeFunc指向自定义的函数.可以将多个被hook的方法都转向统一的自定义函数,在此函数中进行方法的分发处理.特点是比较灵活,实现起来有一定难度.
- 声明一个与被hook方法完全相同的新方法,将新方法的Method结构体覆盖到被hook的Method结构体上. 特点是相对简单,但是不够灵活.
几种常见的Dalvik Hook框架实现细节
这里分析三个常见的Dalvik Hook框架:AndFix,DDI和Xposed(均在github开源,链接见附录).其实现细节如下:
其中–表示未修改,ACC_NATIVE,ACC_PUBLIC定义于/dalvik/libdex/DexFile.h, DALVIK_JNI_NO_ARG_INFO定义于/dalvik/vm/JniInternal.h.
值得注意的是DDI框架将registersSize和insSize全部修改为1,是因为其代码只hook了部分类的toString函数,并没有通用性.另外将jniArgInfo修改为DALVIK_JNI_NO_ARG_INFO在部分CPU架构上会出现问题(x86强制要求jniArgInfo为有效值,否则调用方法时直接崩溃).
几种常见的Dalvik Hook框架比较
其实结合以上两篇文章实现一个通用的不依赖android源码的Dalvik Hook框架不是难事:)
参考资料
(文章参考的是以下几个项目2016年12月10日左右的版本)
- https://github.com/alibaba/AndFix
- https://github.com/rovo89
- https://github.com/crmulliner/ddi
0 0
- 几种Dalvik Hook方案研究
- Android平台下Dalvik层hook框架ddi的研究
- Android平台下Dalvik层hook框架ddi的研究
- Android平台下Dalvik层hook框架ddi的研究
- 嵌入式研究-几种典型 Linux 内核配置方案
- 嵌入式研究-几种典型 Linux 内核配置方案
- 10001.嵌入式研究-几种典型 Linux 内核配置方案
- 嵌入式Linux研究-对几种典型的系统的内核配置方案
- IOS研究之IOS下TTS语音合成的几种方案
- 几种排序方案
- 几种流媒体方案
- 保护内核HOOK的几种方式~~~
- NDIS HOOK的几种方法
- API Hook的几种实现
- HOOK API 的几种方式
- HOOK 几种实现方式区别
- HOOK 几种实现方式区别
- MySQL高可用方案几种方案
- Html初步介绍二
- CSS学习笔记:flexbox
- Default arguments VS Overloading
- 关于Visual C++增量链接以及.textbss
- Android 自定义View 之测量过程(onMeasure)
- 几种Dalvik Hook方案研究
- 各大互联网公司如何面试社招程序员
- 10.8交互式绘图
- Centos 6 Install Ovirt
- 素数
- 什么是支付账户、备付金、网络支付、银行卡清算、贷记卡、代扣、代付....
- SGI STL学习笔记(1):空间配置器(allocator)
- opnet之作者设计csma
- JavaWeb学习总结——Session总结