本地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)
相关推荐
Shadow(⊙o⊙)7 小时前
QT常用控件1.0,enabled() geometry() QIcon的.qrc文件导入
开发语言·c++·qt
wuminyu7 小时前
Java锁膨胀机制之偏向锁到轻量级锁源码剖析
java·linux·c语言·jvm·c++
葱卤山猪7 小时前
二进制字节流序列化
c++·序列化
Lazionr7 小时前
类和对象(中):对象生命周期与运算符重载
c++
凡人叶枫7 小时前
Effective C++ 条款13:以对象管理资源(RAII)
java·linux·开发语言·c++·嵌入式开发
星恒随风7 小时前
C++ 类和对象入门(六):友元、内部类、匿名对象和编译器优化
开发语言·c++·笔记·学习·状态模式
Irissgwe7 小时前
C++ STL 详解:stack 和 queue 的介绍使用与模拟实现
c++·stl·queue·stack
油炸自行车7 小时前
【bug】Qt 6 Q_NAMESPACE 跨 DLL 链接错误:LNK2019 无法解析 staticMetaObject
数据库·c++·qt·bug·link2019·q_namespace_exp·namespaceexport
插件开发7 小时前
英伟达cuda程序通用性关键 geforce 20xx代到最新版 在20xx上编译的c++程序可以通用吗?
java·c++·人工智能
BestOrNothing_20157 小时前
ROS2 C++ 小车控制完整实战(三):自定义 srv 服务通信保姆级教程
c++·service通信·ros2·client·server·srv