本地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)
相关推荐
小六子成长记12 小时前
【C++】:多态的实现
开发语言·c++
chen_22712 小时前
动态桌面方案
c++·qt·ffmpeg·kanzi
liulilittle12 小时前
OPENPPP2 Code Analysis Three
网络·c++·网络协议·信息与通信·通信
꧁Q༒ོγ꧂12 小时前
算法详解(一)--算法系列开篇:什么是算法?
开发语言·c++·算法
橘颂TA12 小时前
【剑斩OFFER】算法的暴力美学——力扣:1047 题:删除字符串中的所有相邻重复项
c++·算法·leetcode·职场和发展·结构于算法
早日退休!!!12 小时前
GCC与LLVM编译器深度解析:核心原理与差异对比(小白向)
c++·编辑器
ChoSeitaku12 小时前
15.C++入门:list|构造|使用|迭代器失效
开发语言·c++·list
R&ain12 小时前
C++中的深浅拷贝
开发语言·c++
R&ain12 小时前
C++的内联函数
c++·算法
羑悻的小杀马特12 小时前
gflags+spdlog实战:C++命令行参数与高性能日志的极致搭配行动指南
c++·spdlog·gflags