CVE-2026-27820
CRITICAL9.8EPSS 0.02%Buffer Overflow in Zlib::GzipReader ungetc via large input leads to memory corruption
描述
### Details A buffer overflow vulnerability exists in `Zlib::GzipReader`. The `zstream_buffer_ungets` function prepends caller-provided bytes ahead of previously produced output but fails to guarantee the backing Ruby string has enough capacity before the memmove shifts the existing data. This can lead to memory corruption when the buffer length exceeds capacity. ### Recommended action We recommend to update the `zlib` gem to version 3.2.3 or later. In order to ensure compatibility with bundled version in older Ruby series, you may update as follows instead: * For Ruby 3.2 users: Update to zlib 3.0.1 * For Ruby 3.3 users: Update to zlib 3.1.2 You can use gem update zlib to update it. If you are using bundler, please add `gem "zlib", ">= 3.2.3"` to your Gemfile. ### Affected versions zlib gem 3.2.2 or lower ### Credits [calysteon](https://hackerone.com/calysteon) ### References * https://hackerone.com/reports/3467067
受影響套件(5)
- Alpine/rubyfrom 0, < 3.4.9-r0
- Debian/ruby2.7from 0
- Debian/ruby3.1from 0
- Debian/ruby3.3from 0
- RubyGems/zlib>= 3.2.0, < 3.2.3
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 4.0 | — | CVSS:4.0/AV:L/AC:L/AT:N/PR:N/UI:P/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N/E:U |
| osv | CVSS 3.1 | CRITICAL9.8 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H |
參考連結(8)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-27820
- ADVISORYhttps://security.alpinelinux.org/vuln/CVE-2026-27820
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-27820
- PATCHhttps://github.com/ruby/zlib
- WEBhttps://github.com/rubysec/ruby-advisory-db/blob/master/gems/zlib/CVE-2026-27820.yml
- WEBhttps://github.com/ruby/zlib/security/advisories/GHSA-g857-hhfv-j68w
- WEBhttps://hackerone.com/reports/3467067
- WEBhttps://www.ruby-lang.org/en/news/2026/03/05/buffer-overflow-zlib-cve-2026-27820