dlsym
dlsym,dlvsym – 从一个动态链接库或者可执行文件中获取到符号地址。
用法
#include
void *dlsym(void *handle, const char *symbol);
#define _GNU_SOURCE
#include
void *dlvsym(void *handle, char *symbol, char *version);
Link with -ldl.
详解
函数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)来判断。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/130647.html