CVE-2026-24895
FrankenPHP is a modern application server for PHP. Prior to 1.11.2, FrankenPHP’s CGI path splitting logic improperly handles Unicode characters during case conversion. The logic computes the split index (for finding .php) on a lowercased copy of the request path but applies that byte index to the original path. Because strings.ToLower() in Go can increase the byte length of certain UTF-8 characters (e.g., Ⱥ expands when lowercased), the computed index may not align with the correct position in the original string. This results in an incorrect SCRIPT_NAME and SCRIPT_FILENAME, potentially causing FrankenPHP to execute a file other than the one intended by the URI. This vulnerability is fixed in 1.11.2.
EPSS 0.03% · 8.8th percentile
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| github.com | dunglas/frankenphp | 0 |
| php | frankenphp | < 1.11.2, 0 |
Timeline
- Feb 12, 2026 CVE Published
- Feb 12, 2026 PoC Published
- Feb 13, 2026 EPSS Score
- Feb 15, 2026 EPSS Score
- Feb 16, 2026 PoC Published
- Feb 17, 2026 EPSS Score
- Feb 17, 2026 PoC Published
- Feb 19, 2026 EPSS Score
- Feb 21, 2026 EPSS Score
- Feb 22, 2026 EPSS Score
- Feb 24, 2026 EPSS Score
- Feb 26, 2026 EPSS Score
References
- https://github.com/php/frankenphp/security/advisories/GHSA-g966-83w7-6w38 url
- https://github.com/php/frankenphp/commit/04fdc0c1e8fde94e2c1ad86217e962c88d27c53e url
- https://github.com/php/frankenphp/releases/tag/v1.11.2 url
- https://nvd.nist.gov/vuln/detail/CVE-2026-24895 advisory
- https://github.com/php/frankenphp package