XML injection (XXE) In phpoffice/phpexcel
Description
XXE in PHPSpreadsheet due to incomplete fix for previous encoding issue 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.
Mitigation
Update Impact
Minimal update. May introduce new vulnerabilities or breaking changes.
Ecosystem | Package | Affected version | Patched versions |
|---|---|---|---|
packagist | - | ||
packagist | 1.8.0 |
Aliases
1. 2. 3. 4.
References
1. 2. 3. 4. 5. 6.