0

0

系统共享库加载路径加固及LD_PRELOAD防御

舞夢輝影

舞夢輝影

发布时间:2026-03-16 17:06:31

|

650人浏览过

|

来源于php中文网

原创

LD_PRELOAD在setuid程序中被glibc主动清空,唯一全局生效的是需root权限的/etc/ld.so.preload;LD_LIBRARY_PATH不安全,应优先使用/etc/ld.so.conf.d/并执行ldconfig;dlopen需用RTLD_GLOBAL且确保符号显式导出;链接器问题可用--verify模式诊断。

系统共享库加载路径加固及ld_preload防御

LD_PRELOAD 被绕过?检查 /etc/ld.so.preload 和 setuid 状态

很多以为设了 LD_PRELOAD 就能拦截所有函数调用,结果在 setuid 程序(比如 sudopasswd)里完全失效——不是配置错了,是内核和 glibc 主动丢弃了它。只要目标进程有 setuid/setgid 位,glibc 会直接清空 LD_PRELOADLD_LIBRARY_PATH,连日志都不留。

真正能持久生效的只有 /etc/ld.so.preload,但它要求 root 权限写入,且对所有动态链接程序全局生效(包括 init 进程启动的守护进程)。更隐蔽的风险是:如果攻击者已拿到 root,ta 可以直接改这个文件,你的 preload 防御反而成了后门入口。

  • 确认目标进程是否 setuid:ls -l /usr/bin/sudo → 看权限位里有没有 s
  • 检查 preload 文件是否被篡改:stat /etc/ld.so.preload + lsattr /etc/ld.so.preload
  • 加固建议:用 chattr +i /etc/ld.so.preload 锁定(但得先停掉所有可能写它的服务)

系统库路径被恶意覆盖?优先用 /etc/ld.so.conf.d/ 而非 LD_LIBRARY_PATH

LD_LIBRARY_PATH 看似方便,实则是最不安全的路径控制方式:它可被任意用户进程设置,且优先级高于系统配置,容易被注入或污染。而 /etc/ld.so.conf.d/ 下的文件由管理员维护,经 ldconfig 编译进二进制缓存,加载时不可被运行时环境变量覆盖。

但注意:ldconfig 不会自动重载,改完配置必须手动执行,否则新路径根本不会生效;另外,32/64 位库要分开放(/usr/lib vs /usr/lib64),混放会导致 ldconfig -p 显示不全甚至跳过整个目录。

  • 添加可信路径:echo "/opt/mysec/lib" > /etc/ld.so.conf.d/mysec.conf
  • 立即生效:ldconfig(非 ldconfig -v,后者只打印不更新缓存)
  • 验证是否加载:ldconfig -p | grep mysec,不是 ldd 某个二进制

dlopen 加载失败却没报错?检查 RTLD_GLOBAL 和符号可见性

dlopen 手动加载 so 时,常见现象是返回非 NULL 句柄,但后续 dlsym 找不到函数——问题往往不在路径或符号名,而在加载标志。默认 RTLD_LOCAL 会让符号仅在当前 dlopen 的模块内可见,无法被后续其他模块(包括主程序)解析。

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

下载

另一个坑是编译时加了 -fvisibility=hidden 却没显式用 __attribute__((visibility("default"))) 标出导出函数,导致 dlsym 查不到任何符号,连 nm -D 都看不到。

  • 确保导出函数可见:nm -D yourlib.so | grep your_func,无输出就说明没导出
  • 加载时用 RTLD_GLOBALdlopen("libfoo.so", RTLD_LAZY | RTLD_GLOBAL)
  • 避免在同一个进程中反复 dlopen/dlclose 同一库:glibc 不保证 dlclose 后符号表清理干净,可能引发 undefined symbol

加固后程序启动失败?检查 /lib64/ld-linux-x86-64.so.2 的 --verify 模式

系统级加固常涉及替换或包装动态链接器(如用自定义 ld-linux-x86-64.so.2 插入校验逻辑),但一旦出错,程序会静默退出,strace 里只看到 execve 返回 -ENOENT 或直接 segfault——因为链接器自己挂了,连 libc 都没机会初始化。

真正能定位问题的是链接器内置的 --verify 模式:它不执行程序,只做依赖解析和符号检查,能快速暴露路径缺失、ABI 不匹配或 preload 库版本冲突。

  • 验证链接器行为:/lib64/ld-linux-x86-64.so.2 --verify ./myapp
  • 若提示 cannot load library,重点查 ldd ./myapp 输出中第一行的 interpreter 路径是否真实存在
  • 不要用 patchelf 直接改 interpreter 路径到未签名的自定义链接器——内核的 CONFIG_SECURITY_LOAD_UBSAN 或 SELinux 策略可能直接拒载

真正的难点从来不是加什么,而是删什么:你得清楚哪些路径、哪些预加载项、哪些链接器特性,在特定上下文里是冗余甚至危险的。删错一个,整个信任链就断了。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1132

2024.03.01

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6584

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3351

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1705

2025.12.25

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

237

2023.12.07

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1564

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

716

2023.06.29

chatgpt官网入口地址合集
chatgpt官网入口地址合集

本专题整合了chatgpt官网入口地址、使用教程等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号