CVE-2026-34084
Analyzed
Analyzed - Analysis Complete
Phar Deserialization RCE in PhpSpreadsheet Library
Publication date: 2026-05-05
Last updated on: 2026-05-08
Assigner: GitHub, Inc.
Description
Description
PhpSpreadsheet is a library for reading and writing spreadsheet files. In versions 1.30.2 and earlier, 2.0.0 through 2.1.14, 2.2.0 through 2.4.3, 3.3.0 through 3.10.3, and 4.0.0 through 5.5.0, when the filename argument to IOFactory::load() is user-controlled, an attacker can supply a PHP stream wrapper path (such as phar://, ftp://, or ssh2.sftp://) that passes the is_file() check in File::assertFile(). The phar:// wrapper triggers deserialization of the PHAR metadata, which can lead to remote code execution if a suitable gadget chain is available in the application. The ftp:// and ssh2.sftp:// wrappers can be used for server-side request forgery. This issue has been fixed in versions 1.30.3, 2.1.15, 2.4.4, 3.10.4, and 5.6.0.
CVSS Scores
EPSS Scores
| Probability: | |
| Percentile: |
Meta Information
Affected Vendors & Products
| Vendor | Product | Version / Range |
|---|---|---|
| phpoffice | phpspreadsheet | to 1.30.3 (exc) |
| phpoffice | phpspreadsheet | From 2.0.0 (inc) to 2.1.15 (exc) |
| phpoffice | phpspreadsheet | From 2.2.0 (inc) to 2.4.4 (exc) |
| phpoffice | phpspreadsheet | From 3.3.0 (inc) to 3.10.4 (exc) |
| phpoffice | phpspreadsheet | From 4.0.0 (inc) to 5.6.0 (exc) |
Helpful Resources
Exploitability
| CWE ID | Description |
|---|---|
| CWE-502 | The product deserializes untrusted data without sufficiently ensuring that the resulting data will be valid. |
| CWE-918 | The web server receives a URL or similar request from an upstream component and retrieves the contents of this URL, but it does not sufficiently ensure that the request is being sent to the expected destination. |