不能使用MSHookFunction挂钩某些库调用
Cannot hook certain library calls using MSHookFunction
我在使用MobileSubstrate的MSHookFunction()来挂钩某些库函数调用时遇到麻烦。例如,挂钩memcpy和memset会导致应用程序启动时崩溃,而挂钩memcmp则可以正常工作。
我认为这是因为钩子代码本身使用这些函数调用?
是否有任何方法在iOS上挂钩memcpy和memset ?
我一直没有弄清这件事的真相。我在想,也许MobileSubstrate调用函数在同一内存页,我试图挂钩,因此内存保护得到所有搞砸了。
我通过编写自己的钩子函数来解决这个问题。
对于memcpy和opendir,我得到了相同的情况。iPhone 5, iOS6.1.2
MSHookFunction有时返回奇数(xxxx3)地址作为原始例程的地址。
我也遇到过这种情况,我认为失败的原因是加载器作为dlsym为memcpy返回的函数实际上不是一个真正的函数,而是它的存根。我已经转储了地址和字节,分离了libsystem_c,并验证了dlsym(RTLD_DEFAULT, "memcpy")返回给我的函数
<>之前;*memcpy_0(Void *, const Void *, size_t)__picsymbolstub4:3947B37C EXPORT _memcpy_0 . c__picsymbolstub4:3947B37C _memcpy_0;代码XREF: _strlcpy+22p__picsymbolstub4:3947B37C ;_strlcpy + 32 p…__picsymbolstub4:3947B37C LDR R12, =(_memcpy_ptr - 0x3947B388);j__memcpy__picsymbolstub4:3947B380 ADD R12, PC, R12;_memcpy_ptr__picsymbolstub4:3947B384 LDR PC, [R12];_memcpy__picsymbolstub4:3947B384;函数_memcpy_0结束__picsymbolstub4:3947B388 off_3947B388 DCD _memcpy_ptr - 0x3947B388之前可以看到,这段代码与PC相关,这可能就是MSHook失败的原因。如果您尝试钩住实际的函数,也就是这个存根调用的函数,它可以工作。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 函数调用中参数的顺序重要吗
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在c++类上调用void函数
- 为什么 std::unique 不调用 std::sort?
- 调用专用模板时出错"no matching function for call to [...]"
- 选择要调用的构造函数
- C++为什么尽管我调用了void函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 没有为自己的结构调用列表推回方法
- 调用'begin(int [n])'没有匹配函数
- 什么时候调用析构函数
- 如何用参数值调用函数(仅在运行时已知)
- std::cout.imbue()多重调用
- 函数何时会在c++中包含stack_Unwind_Resume调用