漏洞评级
高危漏洞
确认受影响版本
0.6.18 - 1.20.0
确认修复版本
1.21.0、1.20.1
厂商
F5, Inc
厂商官网
https://nginx.org/
厂商参考资料
https://mailman.nginx.org/pipermail/nginx-announce/2021/000300.html
漏洞CVE
CVE-2021-23017
CWE
193
CVSS评分
8.1
漏洞概述及影响
在处理DNS响应时,ngx_resolver_copy()中的一个off-by-one错误将允许网络攻击者在堆分配的缓冲区中写入超出边界的点字符(‘.’, 0x2E)。配置解析程序原语时,响应nginx服务器DNS请求的DNS响应可能会触发该漏洞。精心构造的数据包可以通过使用0x2E覆盖下一个堆块元数据的最低有效字节,此时,能够向nginx服务器提供DNS响应的网络攻击者可以实现拒绝服务攻击或远程代码执行攻击。
由于nginx中缺少DNS欺骗防御措施,并且在检查DNS事务ID之前调用了易受攻击的函数,因此远程攻击者可以通过在可行的时间内向目标服务器发送恶意DNS响应来利用该漏洞实施攻击。
漏洞成因分析
nginx的DNS解析器(core/ngx_resolver.c)可以在设置解析器原语时,通过DNS解析多个模块的主机名。
ngx_resolver_copy()会被调用以验证和解压缩DN