CVE-2023-36464
MEDIUM6.2EPSS 0.09%pypdf and PyPDF2 possible Infinite Loop when a comment isn't followed by a character
Published: 6/30/2023Modified: 4/28/2026
Description
pypdf is an open source, pure-python PDF library. In affected versions an attacker may craft a PDF which leads to an infinite loop if `__parse_content_stream` is executed. That is, for example, the case if the user extracted text from such a PDF. This issue was introduced in pull request #969 and resolved in pull request #1828. Users are advised to upgrade. Users unable to upgrade may modify the line `while peek not in (b"\r", b"\n")` in `pypdf/generic/_data_structures.py` to `while peek not in (b"\r", b"\n", b"")`.
Affected packages (4)
- Debian/pypdffrom 0, < 3.4.1-1+deb12u1
- Debian/pypdf2from 0, < 2.12.1-3+deb12u1
- PyPI/pypdf>= 3.1.0, < 3.9.0
- PyPI/pypdf2>= 2.2.0, <= 3.0.1
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM6.2 | CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H |
References (8)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2023-36464
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2023-36464
- PATCHhttps://github.com/py-pdf/pypdf
- WEBhttps://github.com/py-pdf/pypdf/commit/b0e5c689df689ab173df84dacd77b6fc3c161932
- WEBhttps://github.com/py-pdf/pypdf/pull/1828
- WEBhttps://github.com/py-pdf/pypdf/pull/969
- WEBhttps://github.com/py-pdf/pypdf/releases/tag/3.9.0
- WEBhttps://github.com/py-pdf/pypdf/security/advisories/GHSA-4vvm-4w3v-6mr8