关于libxml2 XML外部实体注入漏洞(CVE-2024-40896)的安全预警
一、 基本情况
libxml2是一个开源、高性能且应用广泛的XML解析库,它基于标准的ANSI C库完成,提供了丰富的API接口,支持XML文档的读取、创建、修改、验证和查询等功能,并兼容多种操作系统,包括 Linux、Windows、macOS 和其他类 UNIX 系统,可嵌入在多种编程语言中(如 C、Python、Ruby、Perl 等)。
二、 漏洞描述
libxml2中存在一个XML外部实体注入漏洞(CVE-2024-40896),该漏洞的CVSS评分为9.1。
由于libxml2受影响版本中的SAX 解析器在处理外部实体时,即使开发者在自定义的 SAX 处理器中尝试通过某种方式(例如设置“checked”)来控制或覆盖外部实体的加载,解析器仍会触发与外部实体相关的事件。攻击者可通过向目标 XML 解析器提供包含外部实体引用的恶意 XML 输入来利用该漏洞,成功利用可能导致信息泄露(如访问文件系统的敏感文件)、拒绝服务或执行其他未授权操作。
三、 影响范围
2.11 <= libxml2 < 2.11.9
2.12 <= libxml2 < 2.12.9
2.13 <= libxml2 < 2.13.3
四、 修复建议
目前该漏洞已经修复,受影响用户可升级到以下版本:
libxml2 2.11.x >= 2.11.9
libxml2 2.12.x >= 2.12.9
libxml2 2.13.x >= 2.13.3
下载链接:
https://gitlab.gnome.org/GNOME/libxml2/-/releases
五、 参考链接
https://gitlab.gnome.org/GNOME/libxml2/-/issues/761
https://nvd.nist.gov/vuln/detail/CVE-2024-40896