本地preload hook案例

目的

实现通过LD_PRELOAD 对运行程序的malloc,free进行hook

hook代码实现

hook.c

arduino 复制代码
#define _GNU_SOURCE
#include <stdio.h>
#include <dlfcn.h>

static void* (*real_malloc)(size_t size);
static void  (*real_free)(void *ptr);

__attribute__((constructor))
static void init()
{
    real_malloc = dlsym(RTLD_NEXT, "malloc");
    real_free   = dlsym(RTLD_NEXT, "free");
}

void *malloc(size_t size)
{
    void *ptr = real_malloc(size);
    fprintf(stderr, "malloc(%zd) = %p\n", size, ptr);
    return ptr;
}

void free(void *ptr)
{
    real_free(ptr);
    fprintf(stderr, "free(%p)\n", ptr);
}

编译为so

vbnet 复制代码
clang hook.c -shared -fPIC -ldl -o hook.so

测试代码

main.c

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int main()
{
	char* a = (char*)malloc(sizeof(char)*5);

	free(a);
}

编译为可执行文件

css 复制代码
clang main.c -o main 

hook结果

运行

bash 复制代码
LD_PRELOAD=$PWD/hook.so ./main

结果

scss 复制代码
malloc(5) = 0x559d34500260
free(0x559d34500260)
相关推荐
ShineSpark几秒前
C++面试11——指针与引用
c++·面试
杨小码不BUG21 分钟前
CSP-J/S初赛知识点精讲-图论
c++·算法·图论··编码·csp-j/s初赛
初圣魔门首席弟子38 分钟前
flag使用错误出现bug
c++·bug
Mr_WangAndy1 小时前
C++设计模式_创建型模式_原型模式Prototype
c++·设计模式·原型模式
奔跑吧邓邓子1 小时前
【C++实战㊷】C++ 原型模式实战:从概念到高效应用
c++·实战·原型模式
奔跑吧邓邓子2 小时前
【C++实战㊶】C++建造者模式:复杂对象构建的秘密武器
c++·实战·建造者模式
奔跑吧邓邓子2 小时前
【C++实战㊵】C++抽象工厂模式:解锁高效对象创建的密钥
c++·实战·抽象工厂模式
jf加菲猫3 小时前
条款11:优先选用删除函数,而非private未定义函数
开发语言·c++
怀旧,4 小时前
【C++】23. C++11(上)
开发语言·c++
小卡皮巴拉4 小时前
【笔试强训】Day1
开发语言·数据结构·c++·算法