当前位置: 首页 > news >正文

在iphone越狱机器中使用Hook

由于有不少朋友需要该文章的Demo,一个个发送比较麻烦,我写了个类似的Demo,放在csdn上,无需积分,如有需要可直接下载。工程文件等都是按照文章描述的方式进行创建的。另libsubstrate.dylib非i386架构的,故必须使用真机编译,真机调试。

下载地址:http://download.csdn.net/detail/pp1pp1pp2/5253930

在iphone越狱机器中使用Hook

  1. 下载libsubstrate.dylib动态库及substrate.h头文件,加入项目中。该动态库由越狱团队提供,使用该动态库,可以动态更换内存的代码。关于MobileSubstrate wiki上有篇文章说得很好。
  2. 确定需要进行hook的对象。

例如:我打算在系统每次传递消息之前,都进行一些定制的处理,那么就可以Hook UIWindow的sendEvent函数。

 

新建一个工程普通base view普通工程项目,项目名称为Hook2

MessageHook.h

#import <UIKit/UIKit.h>


#ifndef __MESSAGE_HOOK_H__
#define __MESSAGE_HOOK_H__

extern "C"
{
	extern IMP original_UIWindow_sendEvent;

	extern void replace_UIWindow_sendEvent(UIWindow *self, SEL cmd, UIEvent *event);
}

#endif // __MESSAGE_HOOK_H__

  

MessageHook.mm

#import "MessageHook.h"

// 定义需要被hook的函数
IMP original_UIWindow_sendEvent;

// 定义hook函数
void replace_UIWindow_sendEvent(UIWindow *self, SEL cmd, UIEvent *event)
{
	NSLog(@"replease_UIWindow_sendEvent is call In Hook2");
	
	original_UIWindow_sendEvent(self, cmd, event);
}

  

注意该实现函数的文件名称后缀为.mm,也即支持C++混合编译,否则在导入C/C++类型的头文件或相关代码时,编译会报错。

MessageHook.h包括被hook函数的声明以及hook函数的声明。

  1. 在XCode中配置OTHER_LDFLAGS为-init  _$(PROJECT_NAME)Initialize –lsubstrate –dynamiclib

OTHER_LDFLAGS 在Build Settings----Linking-----Other Linker Flags)

表示在连接阶段需要subsrate以及dynaliclib动态库。而-init $(PROJECT_NAME)Initialize则是定义工程所编译出来的动态库加载过后的初始化函数。

由于我们的工程项目名称为Hook2,所以我们需要新建一个文件为Hook2Initialize.mm,在运行时,系统会根据声称的dylib来寻找初始化函数,该函数是$(PROJECT_NAME)文件中的$(PROJECT_NAME)Initialize函数。

故在Hook2Initialize.mm中包含Hook2Initialize的函数实现.

#import "substrate.h"
#import "MessageHook.h"

extern "C" void Hook2Initialize()
{
	NSLog(@"Hook2Initialize Start.");
	
	NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
	// 配置被hook的函数以及hook函数以及指向被hook函数的函数指针(IMP)之间的关联
    MSHookMessageEx([UIWindow class], @selector(sendEvent:), (IMP)replace_UIWindow_sendEvent, (IMP *)&original_UIWindow_sendEvent);
	
	[pool release];
	
	NSLog(@"Hook2Initialize End.");
}

  

编译成功之后生成的Hook2文件夹,显示包内容,更改其中的Hook2文件为Hook2.dylib, 即可通过iphone explorer来将Hook2.dylib放置到/Library/MobileSubstate/DynamicLibraries文件夹中,ReSpring,就看以看到任何一次拖动界面等操作,都会打印出replease_UIWindow_sendEvent is call In Hook2,说明我们的事件截获成功了。

 

这边我不知道怎么上传附件,所以每办法去上传示例工程。有知道的可以告诉我,不甚感激

大家可以加入QQ群:3078698,进行讨论。

 

相关文章:

  • 报错:具有键...的ViewData项属于类型...,但它必须属于类型IEnumerableSelectListItem...
  • DELPHI7在WIN8和WIN10下安装和运行
  • mysql 如何选择随机行
  • 字符串通信协议解析函数
  • 虚拟机下host-only模式服务器之间通信
  • DATASNAP远程方法返回TSTREAM正解
  • 对比学习UIKit和AppKit--入门级
  • SVM算法入门
  • 分布函数(连续型连续型)
  • iOS应用开发攻略(助你iOS开发中攻城拔寨)
  • 在Struts2标签s:textfield中显示正确的日期
  • sql 用户定义函数自动生成自增长ID
  • 免费的精品: Productivity Power Tools 动画演示
  • C++之solmyr小品文
  • CMake的应用(在vision studio2008中去掉 ALL_BUILD 和 ZERO_CHECK)
  • php的引用
  • 【Linux系统编程】快速查找errno错误码信息
  • 77. Combinations
  • crontab执行失败的多种原因
  • es6(二):字符串的扩展
  • HomeBrew常规使用教程
  • JavaScript-Array类型
  • JavaScript工作原理(五):深入了解WebSockets,HTTP/2和SSE,以及如何选择
  • MYSQL如何对数据进行自动化升级--以如果某数据表存在并且某字段不存在时则执行更新操作为例...
  • Rancher如何对接Ceph-RBD块存储
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 聊聊spring cloud的LoadBalancerAutoConfiguration
  • 买一台 iPhone X,还是创建一家未来的独角兽?
  • 数据仓库的几种建模方法
  • 学习JavaScript数据结构与算法 — 树
  • 回归生活:清理微信公众号
  • #NOIP 2014# day.1 生活大爆炸版 石头剪刀布
  • #NOIP 2014# day.2 T2 寻找道路
  • (独孤九剑)--文件系统
  • (二开)Flink 修改源码拓展 SQL 语法
  • (十)DDRC架构组成、效率Efficiency及功能实现
  • (四)【Jmeter】 JMeter的界面布局与组件概述
  • (提供数据集下载)基于大语言模型LangChain与ChatGLM3-6B本地知识库调优:数据集优化、参数调整、Prompt提示词优化实战
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • (最简单,详细,直接上手)uniapp/vue中英文多语言切换
  • .mysql secret在哪_MySQL如何使用索引
  • .NET Core使用NPOI导出复杂,美观的Excel详解
  • .NET 药厂业务系统 CPU爆高分析
  • .NET设计模式(8):适配器模式(Adapter Pattern)
  • .net之微信企业号开发(一) 所使用的环境与工具以及准备工作
  • /*在DataTable中更新、删除数据*/
  • @ComponentScan比较
  • [].shift.call( arguments ) 和 [].slice.call( arguments )
  • [3D基础]理解计算机3D图形学中的坐标系变换
  • [Android] Upload package to device fails #2720
  • [C++]STL之map
  • [CSS]文字旁边的竖线以及布局知识
  • [E单调栈] lc2487. 从链表中移除节点(单调栈+递归+反转链表+多思路)
  • [FC][常见Mapper IRQ研究]