dlsym
dlsym,dlvsym – 从一个动态链接库或者可执行文件中获取到符号地址。
用法
#include <dlfcn.h>
void *dlsym(void *handle, const char *symbol);
#define _GNU_SOURCE
#include <dlfcn.h>
void *dlvsym(void *handle, char *symbol, char *version);
Link with -ldl.
Jetbrains全家桶1年46,售后保障稳定
详解
函数dlsym()的第一个参数是一个指向已经加载的动态目标的句柄,这个句柄可以是dlopen()函数返回的。
其中symbol参数是一个以null结尾的符号名。
返回值是这个符号加载到内存中的地址。如果这个符号 在指定的目标 或者 在由dlopen(3)装载指定的目标时自动装载的其他共享目标中都没有找到,dlsym()返回NULL指针。(dlsym在这些动态目标中执行广度优先搜索)。
由于符号的值本身可能实际就是NULL,因此,返回的NULL不能直接用来判断是否出错!所以,必须通过dlerror(3)函数以清理掉之前的错误状态,然后调用dlsym(),最后调用dlerror(3),然后将其返回值保存到一个变量,最后检查是否这个保存的变量值不为NULL。
handle参数可能使用如下的两种特殊的伪句柄:
- RTLD_DEFAULT
- 使用默认的共享目标搜索顺序来找到要找的符号第一次出现的地方。这个搜索范围包含可执行文件中的全局符号以及这个可执行文件的依赖项(也就是使用RTLD_GLOBAL标志动态加载的共享目标)
- RTLD_NEXT
- 在当前搜索顺序中找,在当前的目标之后,要找的符号下一次出现的地方。 这就允许向在另一个共享目标中的函数提供一层封装。这样一来,在一个预先加载的共享目标中定义的函数中,就可以找到并调用在另一个共享目标中的真函数(其实就是一种劫持呢!!!!)。或者有多层的预加载的时候的下一层!
返回值
成功时,这些函数返回跟symbol关联的地址。失败时,返回NULL;错误原因可以通过dlerror(3)来判断。