0

0

/etc/ld.so.preload 被篡改导致全局加载恶意 so 的检测清理

舞姬之光

舞姬之光

发布时间:2026-01-26 19:47:02

|

727人浏览过

|

来源于php中文网

原创

直接查看文件内容可快速判断:cat /etc/ld.so.preload,若非空(如含/tmp/.x.so)即被篡改;该文件默认不存在或为空,且权限不应开放写入,属主应为root,否则属异常。

/etc/ld.so.preload 被篡改导致全局加载恶意 so 的检测清理

怎么确认 /etc/ld.so.preload 被篡改了

直接查看文件内容是最快速的判断方式:cat /etc/ld.so.preload。如果输出非空(比如出现类似 /tmp/.x.so/var/tmp/libhook.so 的路径),基本可断定已被植入。该文件本应为空或根本不存在——Linux 默认不创建它,任何内容都属于异常。

还要注意权限和属主:ls -l /etc/ld.so.preload。正常情况不该有写权限(尤其对 non-root 用户),若看到 -rw-rw-rw- 或属主是 daemon/nobody,就是强信号。

  • 该文件被读取时机极早:在 main() 执行前,由动态链接器 ld-linux.so 加载,所有用户态进程(包括 lsps 甚至 bash)都会强制加载其中指定的 so
  • 恶意 so 常驻内存后,可能绕过常规进程检测(ps 看不到独立进程,但 lsof -nP -p 1 可能暴露异常库)
  • 有些后门会用绝对路径指向已删除文件(/dev/shm/.a.so (deleted)),这时 cat 看不到内容,但 readlink /proc/1/map_files/...gdb -p 1 -ex 'info sharedlibrary' -ex quit 才能发现

ld.so.preload 里写的路径为什么能生效

因为 glibc 的动态链接器硬编码了这个路径查找逻辑:只要文件存在且格式合法(ELF shared object)、有执行权限、符号表可解析,就会在每个进程启动时优先 dlopen() 它。它不校验签名,不检查是否在 LD_LIBRARY_PATH 中,也不受 secure-execution 模式限制(除非系统启用了 AT_SECURE 且 preloaded so 不满足 setuid 安全要求)。

这意味着哪怕你用 strace -e trace=openat,openat64 /bin/true,也看不到对那个 so 的 open 调用——它是链接器内部行为,不是用户代码发起的。

  • 相对路径无效:必须是绝对路径,否则加载失败(ld 直接报 cannot open shared object file
  • 路径中不能含空格或特殊 shell 字符,否则解析中断,整行被跳过(但其他行仍有效)
  • 多行支持:每行一个 so,空行和以 # 开头的行会被忽略

清理时要同步处理的三个关键点

删掉 /etc/ld.so.preload 只是第一步。攻击者往往配套部署多个落点,只清文件等于留后门。

微信 WeLM
微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

下载
  • 检查对应 so 文件是否还在磁盘:ls -la $(cat /etc/ld.so.preload 2>/dev/null | head -n1);若显示 (deleted),说明已被 rm 但句柄仍被进程占用,需找出处(lsof | grep deleted)并 kill 相关进程
  • 检查 cron、systemd timer、/etc/init.d/ 脚本里是否有自动恢复该文件的逻辑(常见于定时任务里 echo "/tmp/x.so" > /etc/ld.so.preload
  • 查 rootkit 是否已 hook open()stat() 系统调用:用静态编译的 busybox ls 或从 Live CD 挂载根分区再检查,避免被运行时劫持干扰判断

如何防止再次被写入

最直接有效的是加不可变属性:chattr +i /etc/ld.so.preload。这样即使 root 用户也无法修改或删除,除非先执行 chattr -i。注意:该操作要求文件系统支持 ext2/3/4/xfs 等,btrfs 不支持 +i,zfs 需用 chmod A- 或设置 readonly=on

如果系统不允许加锁(如容器环境或某些云主机),至少确保文件不存在且父目录权限收紧:rm -f /etc/ld.so.preload && chmod 755 /etc,并加入定期校验(例如用 sha256sum /etc/ld.so.preload 2>/dev/null || echo "missing")。

真正难防的是攻击者已获得 root 权限——此时他可以卸载文件系统、绕过 chattr、甚至 patch 内核。所以重点不在“怎么锁死”,而在“怎么早发现”:把 /etc/ld.so.preload 加入 HIDS(如 aide、samhain)监控列表,或用 inotifywait -m -e create,modify /etc 做实时告警。

别忘了检查 /etc/ld.so.cache/etc/ld.so.conf.d/ 下的配置,它们虽不等同于 preload,但也可被用来持久化恶意库路径,且更隐蔽。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能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语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

235

2023.09.22

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

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

437

2024.03.01

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

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

1373

2023.06.21

如何安装LINUX
如何安装LINUX

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

705

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

295

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

778

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

575

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

548

2023.07.20

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

28

2026.01.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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