Home

Description

In PHP versions 8.2.* before 8.2.31, 8.3.* before 8.3.31, 8.4.* before 8.4.21, and 8.5.* before 8.5.6, the SOAP extension's object deduplication mechanism stores pointers to PHP objects in a global map without incrementing their reference counts. When an apache:Map node contains duplicate keys, processing the second entry overwrites the first in the temporary result map, freeing the original PHP object while its stale pointer remains in the map. A subsequent href reference to the freed node can copy the dangling pointer into the result. As PHP string allocations can reclaim the freed memory region, an attacker with control over the SOAP request body can exploit this use-after-free to achieve remote code execution.

PUBLISHED Reserved 2026-04-20 | Published 2026-05-10 | Updated 2026-05-10 | Assigner php




CRITICAL: 9.5CVSS:4.0/AV:N/AC:H/AT:P/PR:N/UI:N/VC:H/VI:H/VA:H/SC:H/SI:H/SA:H/AU:Y/RE:M/U:Red

Problem types

CWE-416 Use After Free

Product status

Default status
affected

8.2.* (semver) before 8.2.31
affected

8.3.* (semver) before 8.3.31
affected

8.4.* (semver) before 8.4.21
affected

8.5.* (semver) before 8.5.6
affected

Credits

brettgervasoni reporter

Ilija Tovilo remediation developer

Nora Dossche remediation reviewer

References

github.com/...hp-src/security/advisories/GHSA-85c2-q967-79q5 vendor-advisory

cve.org (CVE-2026-6722)

nvd.nist.gov (CVE-2026-6722)

Download JSON