一、漏洞信息
漏洞编号:CVE-2023-34455
漏洞归属组件:snappy-java
漏洞归属的版本:1.1.2.4,1.1.8.4
CVSS V3.0分值:
BaseScore:7.5 High
Vector:CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H
漏洞简述:
snappy-java is a fast compressor/decompressor for Java. Due to use of an unchecked chunk length, an unrecoverable fatal error can occur in versions prior to 1.1.10.1.The code in the function hasNextChunk in the fileSnappyInputStream.java checks if a given stream has more chunks to read. It does that by attempting to read 4 bytes. If it wasn’t possible to read the 4 bytes, the function returns false. Otherwise, if 4 bytes were available, the code treats them as the length of the next chunk.In the case that the compressed
variable is null, a byte array is allocated with the size given by the input data. Since the code doesn’t test the legality of the chunkSize
variable, it is possible to pass a negative number (such as 0xFFFFFFFF which is -1), which will cause the code to raise a java.lang.NegativeArraySizeException
exception. A worse case would happen when passing a huge positive value (such as 0x7FFFFFFF), which would raise the fatal java.lang.OutOfMemoryError
error.Version 1.1.10.1 contains a patch for this issue.
漏洞公开时间:2023-06-16 02:15:00
漏洞创建时间:2023-06-16 10:07:21
漏洞详情参考链接:
https://nvd.nist.gov/vuln/detail/CVE-2023-34455
漏洞分析指导链接:
https://gitee.com/openeuler/cve-manager/blob/master/cve-vulner-manager/doc/md/manual.md
漏洞数据来源:
openBrain开源漏洞感知系统
漏洞补丁信息:
二、漏洞分析结构反馈
影响性分析说明:
snappy-java 是 Java 的快速压缩器/解压缩器。由于使用未经检查的块长度,在 1.1.10.1 之前的版本中可能会出现不可恢复的致命错误。文件 SnappyInputStream.java 中函数 hasNextChunk 中的代码检查给定流是否有更多块需要读取。它通过尝试读取 4 个字节来实现这一点。如果无法读取 4 个字节,该函数将返回 false。否则,如果有 4 个字节可用,则代码将它们视为下一个块的长度。在压缩变量为空的情况下,将使用输入数据给定的大小分配字节数组。由于代码没有测试 chunkSize 变量的合法性,因此有可能传递负数(例如 0xFFFFFFFF 为 -1),这将导致代码引发 java.lang.NegativeArraySizeException 异常。当传递一个巨大的正值(例如 0x7FFFFFFF)时,会发生更糟糕的情况,这会引发致命的 java.lang.OutOfMemoryError 错误。版本 1.1.10.1 包含针对此问题的补丁。
openEuler评分:
7.5
Vector:CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H
受影响版本排查(受影响/不受影响):
1.openEuler-20.03-LTS-SP1(1.1.2.4):受影响
2.openEuler-20.03-LTS-SP3(1.1.2.4):受影响
3.openEuler-22.03-LTS(1.1.2.4):受影响
4.openEuler-22.03-LTS-SP1(1.1.2.4):受影响
5.openEuler-22.03-LTS-SP2:受影响
修复是否涉及abi变化(是/否):
1.openEuler-20.03-LTS-SP1(1.1.2.4):否
2.openEuler-20.03-LTS-SP3(1.1.2.4):否
3.openEuler-22.03-LTS(1.1.2.4):否
4.openEuler-22.03-LTS-SP1(1.1.2.4):否
5.openEuler-22.03-LTS-SP2:否
三、漏洞修复
安全公告链接:https://www.openeuler.org/zh/security/safety-bulletin/detail/?id=openEuler-SA-2023-1398
@overweight ,@licihua ,@zhujianwei001 ,@xiezhipeng1 ,@caodongxia ,@dillon_chen
issue处理注意事项:
1. 当前issue受影响的分支提交pr时, 须在pr描述中填写当前issue编号进行关联, 否则无法关闭当前issue;
2. 模板内容需要填写完整, 无论是受影响或者不受影响都需要填写完整内容,未引入的分支不需要填写, 否则无法关闭当前issue;
3. 以下为模板中需要填写完整的内容, 请复制到评论区回复, 注: 内容的标题名称(影响性分析说明, openEuler评分, 受影响版本排查(受影响/不受影响), 修复是否涉及abi变化(是/否))不能省略,省略后cve-manager将无法正常解析填写内容.
影响性分析说明:
openEuler评分: (评分和向量)
受影响版本排查(受影响/不受影响):
1.openEuler-20.03-LTS-SP1(1.1.2.4):
2.openEuler-20.03-LTS-SP3(1.1.2.4):
3.openEuler-22.03-LTS(1.1.2.4):
4.openEuler-22.03-LTS-SP1(1.1.2.4):
修复是否涉及abi变化(是/否):
1.openEuler-20.03-LTS-SP1(1.1.2.4):
2.openEuler-20.03-LTS-SP3(1.1.2.4):
3.openEuler-22.03-LTS(1.1.2.4):
4.openEuler-22.03-LTS-SP1(1.1.2.4):
issue处理具体操作请参考:
https://gitee.com/openeuler/cve-manager/blob/master/cve-vulner-manager/doc/md/manual.md
pr关联issue具体操作请参考:
https://gitee.com/help/articles/4142
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
参考网址 | 关联pr | 状态 | 补丁链接 |
---|---|---|---|
https://nvd.nist.gov/vuln/detail/CVE-2023-34455 | None | None | https://github.com/xerial/snappy-java/commit/3bf67857fcf70d9eea56eed4af7c925671e8eaea |
https://ubuntu.com/security/CVE-2023-34455 | None | None | https://discourse.ubuntu.com/c/ubuntu-pro |
https://www.opencve.io/cve/CVE-2023-34455 | None | None | https://github.com/xerial/snappy-java/commit/3bf67857fcf70d9eea56eed4af7c925671e8eaea |
https://bugzilla.redhat.com/show_bug.cgi?id=CVE-2023-34455 | |||
https://security-tracker.debian.org/tracker/CVE-2023-34455 | |||
http://www.cnnvd.org.cn/web/vulnerability/queryLds.tag?qcvCnnvdid=CVE-2023-34455 |
说明:补丁链接仅供初步排查参考,实际可用性请人工再次确认,补丁下载验证可使用CVE补丁工具。
若补丁不准确,烦请在此issue下评论 '/report-patch 参考网址 补丁链接1,补丁链接2' 反馈正确信息,便于我们不断优化工具,不胜感激。
如 /report-patch https://security-tracker.debian.org/tracker/CVE-2021-3997 https://github.com/systemd/systemd/commit/5b1cf7a9be37e20133c0208005274ce4a5b5c6a1
影响性分析说明:
snappy-java 是 Java 的快速压缩器/解压缩器。由于使用未经检查的块长度,在 1.1.10.1 之前的版本中可能会出现不可恢复的致命错误。文件 SnappyInputStream.java 中函数 hasNextChunk 中的代码检查给定流是否有更多块需要读取。它通过尝试读取 4 个字节来实现这一点。如果无法读取 4 个字节,该函数将返回 false。否则,如果有 4 个字节可用,则代码将它们视为下一个块的长度。在压缩变量为空的情况下,将使用输入数据给定的大小分配字节数组。由于代码没有测试 chunkSize 变量的合法性,因此有可能传递负数(例如 0xFFFFFFFF 为 -1),这将导致代码引发 java.lang.NegativeArraySizeException 异常。当传递一个巨大的正值(例如 0x7FFFFFFF)时,会发生更糟糕的情况,这会引发致命的 java.lang.OutOfMemoryError 错误。版本 1.1.10.1 包含针对此问题的补丁。
openEuler评分:
7.5
Vector:CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H
受影响版本排查(受影响/不受影响):
1.openEuler-20.03-LTS-SP1(1.1.2.4):受影响
2.openEuler-20.03-LTS-SP3(1.1.2.4):受影响
3.openEuler-22.03-LTS(1.1.2.4):受影响
4.openEuler-22.03-LTS-SP1(1.1.2.4):受影响
5.openEuler-22.03-LTS-SP2(1.1.2.4):受影响
修复是否涉及abi变化(是/否):
1.openEuler-20.03-LTS-SP1(1.1.2.4):否
2.openEuler-20.03-LTS-SP3(1.1.2.4):否
3.openEuler-22.03-LTS(1.1.2.4):否
4.openEuler-22.03-LTS-SP1(1.1.2.4):否
5.openEuler-22.03-LTS-SP2(1.1.2.4):否
登录 后才可以发表评论
FileDragTip