CVE-2026-6104 PUBLISHED

Global buffer over-read in mb_convert_encoding() with attacker-supplied encoding

Assigner: php
Reserved: 11.04.2026 Published: 10.05.2026 Updated: 10.05.2026

In PHP versions 8.4. before 8.4.21 and 8.5. before 8.5.6, when an encoding name containing an embedded NUL byte is passed to mb_convert_encoding() or related mbstring functions, the code incorrectly assumes that when strncasecmp() returns 0 it means the strings have the same length. This can lead to out-of-bounds read of global memory, potentially causing a crash or information disclosure or crash. Affected functions include mb_convert_encoding(), mb_detect_encoding(), mb_convert_variables(), and mb_detect_order(), as well as the mbstring.detect_order and mbstring.http_output INI settings.

Metrics

CVSS Vector: CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:L/VI:N/VA:L/SC:L/SI:N/SA:L/RE:M/U:Amber
CVSS Score: 6.3

Product Status

Vendor PHP Group
Product PHP
Versions Default: unaffected
  • affected from 8.4.* to 8.4.21 (excl.)
  • affected from 8.5.* to 8.5.6 (excl.)

Credits

  • Akshay Jain reporter
  • Ilija Tovilo remediation developer

References

Problem Types

  • CWE-125 Out-of-bounds Read CWE