题外话:此教程是一篇严肃的学术探讨类文章,仅仅用于学习研究,也请读者不要用于商业或其他非法途径上,笔者一概不负责哟~~
准备工作
- 非越狱的iPhone手机
- fishhook
Demo 1:
1、新建工程,将fishhook文件拖入工程
data:image/s3,"s3://crabby-images/0c73d/0c73da1bdb41e903e6f6b38ce44841f724374bc1" alt=""
2、我们的目的是hook系统的NSLog函数,编写代码
//函数指针,用来保存原始的函数的地址
static void(*old_nslog)(NSString *format, ...);
//新的NSLog
void myNSLog(NSString *format, ...){
format = @"~~勾上了!\n🐶🐶🐶🐶🐶";
//再调用原来的nslog
old_nslog(format);
}
-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
NSLog(@"点击了屏幕!");
}
3、了解fishhook中的struct rebinding结构体
struct rebinding {
const char *name; //需要HOOK的函数名称,字符串
void *replacement;//替换到哪个新的函数上(函数指针,也就是函数的名称)
void **replaced;//保存原始函数指针变量的指针(它是一个二级指针)
};
定义结构体:
//定义rebinding结构体
struct rebinding nslogBind;
//函数名称
nslogBind.name = "NSLog";
//新的函数地址
nslogBind.replacement = myNSLog;
//保存原始函数地址的变量的指针
nslogBind.replaced = (void *)&old_nslog;
重新绑定:
//数组
struct rebinding rebs[]={nslogBind};
/*
arg1:存放rebinding结构体的数组
arg2:数组的长度
*/
rebind_symbols(rebs, 1);
4、运行,点击屏幕,打印的是我们自己的myNSLog
data:image/s3,"s3://crabby-images/fb422/fb422f3a51c6fd0f855cb213d01a89375e35b447" alt=""
是不是很爽,是不是很简单?好,看点不一样的
Demo2
1、自己写了两个函数func和newFunc:
void func(const char *str){
NSLog(@"%s",str);
}
void newFunc(const char *str){
NSLog(@"勾上了!");
funcP(str);
}
2、现在的目的是想交换func和newFunc,当调用func时,我们调用newFunc,跟Demo1一样的编写代码
data:image/s3,"s3://crabby-images/1a91d/1a91d4caa18954ae2e3af062a4a08dcb8008b5d9" alt=""
3、运行点击屏幕,发现打印的是func中的文字,并不是newFunc的文字
data:image/s3,"s3://crabby-images/f9a03/f9a038464e23244fd4c5c52688b4d6907ee6d5ff" alt=""
代码没有任何问题,但就是勾不住;自己写的函数是勾不住的,具体原因见下回分解 😁
Hook不成功原因:iOS逆向之fishHook原理探究
网友评论