CVE-2019-12331XML External Entity (XXE) Injection in Phpspreadsheet

Severity
8.8HIGHNVD
EPSS
0.1%
top 68.65%
CISA KEV
Not in KEV
Exploit
No known exploits
Timeline
PublishedNov 7
Latest updateNov 20

Description

PHPOffice PhpSpreadsheet before 1.8.0 has an XXE issue. The XmlScanner decodes the sheet1.xml from an .xlsx to utf-8 if something else than UTF-8 is declared in the header. This was a security measurement to prevent CVE-2018-19277 but the fix is not sufficient. By double-encoding the the xml payload to utf-7 it is possible to bypass the check for the string ‚<!ENTITY‘ and thus allowing for an xml external entity processing (XXE) attack.

CVSS vector

CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:HExploitability: 2.8 | Impact: 5.9

Affected Packages3 packages

Packagistphpoffice/phpspreadsheet< 1.8.0
Packagistphpoffice/phpexcel1.8.2

🔴Vulnerability Details

3
OSV
XXE in PHPSpreadsheet due to incomplete fix for previous encoding issue2019-11-20
GHSA
XXE in PHPSpreadsheet due to incomplete fix for previous encoding issue2019-11-20
CVEList
CVE-2019-12331: PHPOffice PhpSpreadsheet before 12019-11-07
CVE-2019-12331 — XML External Entity (XXE) Injection | cvebase