广告
返回顶部
首页 > 资讯 > 操作系统 >怎么检测Linux上的库注入
  • 811
分享到

怎么检测Linux上的库注入

2023-06-16 06:06:10 811人浏览 独家记忆
摘要

这篇文章主要为大家展示了“怎么检测linux上的库注入”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么检测Linux上的库注入”这篇文章吧。共享库漏洞DLL 和 .so 文件都是允许代码(有时

这篇文章主要为大家展示了“怎么检测linux上的库注入”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么检测Linux上的库注入”这篇文章吧。

共享库漏洞

DLL 和 .so 文件都是允许代码(有时候是数据)被不同的进程共享的共享库文件。公用的代码可以放进一个文件中使得每个需要它的进程可以重新使用而不是多次被重写。这也促进了对公用代码的管理。

Linux 进程经常使用这些共享库。(显示共享对象依赖的)ldd 命令可以对任何程序文件显示其共享库。这里有一些例子:

$ ldd /bin/date        linux-vdso.so.1 (0x00007ffc5f179000)        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f02bea15000)        /lib64/ld-linux-x86-64.so.2 (0x00007f02bec3a000)$ ldd /bin/netstat        linux-vdso.so.1 (0x00007ffcb67cd000)        libselinux.so.1 => /lib/x86_64-linux-gnu/libselinux.so.1 (0x00007f45e5d7b000)        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f45e5b90000)        libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f45e5b1c000)        libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f45e5b16000)        /lib64/ld-linux-x86-64.so.2 (0x00007f45e5dec000)        libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f45e5af5000)

linux-vdso.so.1 (在一些系统上也许会有不同的名字)是内核自动映射到每个进程地址空间的文件。它的工作是找到并定位进程所需的其他共享库。

对库加载机制加以利用的一种方法是通过使用 LD_PRELOAD 环境变量。正如 Jaime Blasco 在他的研究中所解释的那样,“LD_PRELOAD 是在进程启动时加载共享库的很简单且非常受欢迎的方法。可以将此环境变量配置到共享库的路径,以便在加载其他共享对象之前加载该共享库。”

为了展示有多简单,我创建了一个极其简单的共享库并且赋值给我的(之前不存在) LD_PRELOAD 环境变量。之后我使用 ldd 命令查看它对于常用 Linux 命令的影响。

$ export LD_PRELOAD=/home/shs/shownum.so$ ldd /bin/date        linux-vdso.so.1 (0x00007ffe005ce000)        /home/shs/shownum.so (0x00007f1e6b65f000)     <== 它在这里        libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f1e6b458000)        /lib64/ld-linux-x86-64.so.2 (0x00007f1e6b682000)

注意,仅仅将新的库赋给 LD_PRELOAD 就影响到了运行的任何程序。

通过设置 LD_PRELOAD 指定的共享库首先被加载(紧随 linux-vdso.so.1),这些库可以极大程度上改变一个进程。例如,它们可以重定向系统调用到它们自己的资源,或对程序运行的行为方式进行意想不到的更改。

osquery 工具可以检测库注入

osquery 工具(可以在 osquery.io下载)提供了一个非常独特的查看 Linux 系统的方式。它基本上将操作系统视作一个高性能的关系数据库。然后,也许你会猜到,这就意味着它可以用来查询并且生成 sql 表,该表提供了诸如以下的详细信息:

  • 运行中的进程

  • 加载的内核模块

  • 打开的网络链接

一个提供了进程信息的内核表叫做 process_envs。它提供了各种进程使用环境变量的详细信息。Jaime Blasco 提供了一个相当复杂的查询,可以使用 osquery 识别出使用 LD_PRELOAD 的进程。

注意,这个查询是从 process_envs 表中获取数据。攻击 ID(T1055)参考 Mitre 对攻击方法的解释。

SELECT process_envs.pid as source_process_id, process_envs.key as environment_variable_key, process_envs.value as environment_variable_value, processes.name as source_process, processes.path as file_path, processes.cmdline as source_process_commandline, processes.cwd as current_working_directory, 'T1055' as event_attack_id, 'Process Injection' as event_attack_technique, 'Defense Evasion, Privilege EScalation' as event_attack_tactic FROM process_envs join processes USING (pid) WHERE key = 'LD_PRELOAD';

注意 LD_PRELOAD 环境变量有时是合法使用的。例如,各种安全监控工具可能会使用到它,因为开发人员需要进行故障排除、调试或性能分析。然而,它的使用仍然很少见,应当加以防范。

同样值得注意的是 osquery 可以交互使用或是作为定期查询的守护进程去运行。了解更多请查阅文章末尾给出的参考。

你也能够通过查看用户的环境设置来定位 LD_PRELOAD 的使用。如果在用户账户中使用了 LD_PRELOAD,你可以使用这样的命令来查看(假定以个人身份登录后):

$ env | grep PRELOADLD_PRELOAD=/home/username/userlib.so

以上是“怎么检测Linux上的库注入”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网操作系统频道!

--结束END--

本文标题: 怎么检测Linux上的库注入

本文链接: https://www.lsjlt.com/news/282695.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么检测Linux上的库注入
    这篇文章主要为大家展示了“怎么检测Linux上的库注入”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么检测Linux上的库注入”这篇文章吧。共享库漏洞DLL 和 .so 文件都是允许代码(有时...
    99+
    2023-06-16
  • 怎么在Linux上检测硬盘上的坏道和坏块
    本篇内容介绍了“怎么在Linux上检测硬盘上的坏道和坏块”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!让我们从坏道和坏块的定义开始说起,它们...
    99+
    2023-06-16
  • 怎么在Linux上扫描/检测新的LUN和SCSI磁盘
    这篇文章主要介绍了怎么在Linux上扫描/检测新的LUN和SCSI磁盘,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。当存储团队将 LUN 与给定的 Linux 主机进行了映射...
    99+
    2023-06-15
  • Linux系统中怎么检测磁盘的IO性能
    这篇文章主要讲解了“Linux系统中怎么检测磁盘的IO性能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux系统中怎么检测磁盘的IO性能”吧!iostat命令可以提供丰富的IO性能状态...
    99+
    2023-06-12
  • 怎么在Linux上检查可用的磁盘空间
    这篇文章主要介绍怎么在Linux上检查可用的磁盘空间,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在 Linux 上查找可用磁盘空间的最简单的方法是使用 df 命令 。df 命令从字面意思上代表着...
    99+
    2023-06-15
  • Linux下怎么使用socktop来检测socket的通讯状况
    本篇内容主要讲解“Linux下怎么使用socktop来检测socket的通讯状况”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux下怎么使用socktop来检测socket的通讯状况”吧!...
    99+
    2023-06-12
  • 怎么在Linux系统上检查所安装的SSH的版本
    本篇内容主要讲解“怎么在Linux系统上检查所安装的SSH的版本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在Linux系统上检查所安装的SSH的版本”吧!检查支持的SSH协议版本方法一如...
    99+
    2023-06-13
  • 怎么在Linux上检查一个软件包的详细信息
    小编给大家分享一下怎么在Linux上检查一个软件包的详细信息,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!YUM 命令:在 RHEL 和 CentOS 系统上获得...
    99+
    2023-06-16
  • 怎么在Gitee上加入别人的仓库
    本篇内容介绍了“怎么在Gitee上加入别人的仓库”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!第一步:注册Gitee账号在加入别人的仓库之前...
    99+
    2023-07-05
  • 怎么在Linux上检查MySQL数据表的存储引擎类型
    这篇文章的内容主要围绕怎么在Linux上检查MySQL数据表的存储引擎类型进行讲述,文章内容清晰易懂,条理清晰,非常适合新手学习,值得大家去阅读。感兴趣的朋友可以跟随小编一起阅读吧。希望大家通过这篇文章有所收获!MySQl主要使用两种存储引...
    99+
    2023-06-28
  • YOLOv5怎么实现在图片上显示统计出单一检测目标的个数
    这篇文章主要介绍“YOLOv5怎么实现在图片上显示统计出单一检测目标的个数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“YOLOv5怎么实现在图片上显示统计出单一检测目标的个数”文章能帮助大家解决问...
    99+
    2023-07-05
  • 怎么将Linux上的PDB数据库传输到windows的CDB数据库
    本篇内容主要讲解“怎么将Linux上的PDB数据库传输到windows的CDB数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么将Linux上的PDB数据...
    99+
    2022-10-19
  • 怎么列出在Linux上已启用或激活的仓库
    这篇文章主要讲解了“怎么列出在Linux上已启用或激活的仓库”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么列出在Linux上已启用或激活的仓库”吧!什么是仓库?存储特定程序软件包的中枢位...
    99+
    2023-06-16
  • 怎么在Linux系统的服务器上使用Memtester进行内存压力测试
    本篇内容介绍了“怎么在Linux系统的服务器上使用Memtester进行内存压力测试”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2023-06-12
  • Linux文件系统误装入到Ocfs2文件系统的数据卷上该怎么恢复
    今天就跟大家聊聊有关Linux文件系统误装入到Ocfs2文件系统的数据卷上该怎么恢复,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、什么是Linux文件系统Linux文件系统中的文...
    99+
    2023-06-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作