一. 漏洞概述
1月26日,Sudo发布安全通告,修复了一个类Unix操作系统在命令参数中转义反斜杠时存在基于堆的缓冲区溢出漏洞。当sudo通过-s或-i命令行选项在shell模式下运行命令时,它将在命令参数中使用反斜杠转义特殊字符。但使用-s或 -i标志运行sudoedit时,实际上并未进行转义,从而可能导致缓冲区溢出。只要存在sudoers文件(通常是 /etc/sudoers),攻击者就可以使用本地普通用户利用sudo获得系统root权限。目前漏洞细节已公开,请受影响的用户尽快采取措施进行防护。
参考链接:
https://www.sudo.ws/alerts/unescape_overflow.html
https://access.redhat.com/security/vulnerabilities/RHSB-2021-002
二. 影响范围
受影响版本
- Sudo 1.8.2 – 1.8.31p2
- Sudo 1.9.0 – 1.9.5p1
不受影响版本
sudo =>1.9.5p2
三. 漏洞检测
3.1 人工检测
用户可以使用非root的账户登录系统,运行“ sudoedit -s / ”命令。
若返回如图以“ sudoedit:”开头的错误,则当前系统可能存在安全风险。
不受影响的系统将显示以“ usage:”开头的错误响应。
四. 漏洞防护
4.1 官方升级
目前官方已在sudo新版本1.9.5p2中修复了该漏洞,请受影响的用户尽快升级版本进行防护,官方下载链接:https://www.sudo.ws/download.html
注:建议用户在升级前做好数据备份工作,避免出现意外
4.2 临时防护措施
若Red Hat相关用户暂时无法进行升级操作,可使用systemtap进行以下临时缓解:
1. 安装所需的systemtap软件包和依赖项:
systemtap yum-utils kernel-devel-"$(uname -r)" |
RHEL 7:使用命令安装 kernel debuginfo:debuginfo-install -y kernel-“$(uname -r)”。
RHEL 8:使用命令安装 sudo debuginfo:debuginfo-install sudo。
2. 创建以下systemtap脚本(将文件命名为sudoedit-block.stap):
probe process("/usr/bin/sudo").function("main") { command = cmdline_args(0,0,""); if (strpos(command, "edit") >= 0) { raise(9); } } |
3. 使用以下命令安装脚本:(使用root权限)
# nohup stap -g sudoedit-block.stap & |
该脚本将使得易受攻击的sudoedit二进制文件停止工作。 sudo命令仍将照常执行。
注:上述更改在重启后失效,必须在每次重启后重新应用。
4. 一旦安装了补丁程序,就可以通过取消systemtap进程来删除systemtap脚本。 例如,通过使用以下命令(其中7590是systemtap进程的PID):
# kill -s SIGTERM 7590 |
声明
本安全公告仅用来描述可能存在的安全问题,绿盟科技不为此安全公告提供任何保证或承诺。由于传播、利用此安全公告所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,绿盟科技以及安全公告作者不为此承担任何责任。
绿盟科技拥有对此安全公告的修改和解释权。如欲转载或传播此安全公告,必须保证此安全公告的完整性,包括版权声明等全部内容。未经绿盟科技允许,不得任意修改或者增减此安全公告内容,不得以任何方式将其用于商业目的。