【活用ガイド】

JVNDB-2026-004436

The PHP GroupのFrankenPHPにおける動作順序 (正規化前の検証) に関する脆弱性

概要

FrankenPHPはPHPのためのモダンなアプリケーションサーバーです。バージョン1.11.2以前のFrankenPHPでは、CGIパス分割ロジックが大文字・小文字変換中のUnicode文字を適切に処理していませんでした。このロジックはリクエストパスの小文字変換されたコピーで分割インデックス(.phpの位置)を計算しますが、そのバイトインデックスを元のパスに適用しています。Go言語のstrings.ToLower()は特定のUTF-8文字(例:小文字化すると拡張されるA)でバイト長を増やす可能性があるため、計算されたインデックスが元の文字列の正しい位置と一致しない場合があります。これにより、誤ったSCRIPT_NAMEおよびSCRIPT_FILENAMEが生成され、URIによって意図されたファイル以外のファイルがFrankenPHPによって実行される可能性があります。この脆弱性はバージョン1.11.2で修正されました。
CVSS による深刻度 (CVSS とは?)

CVSS v3 による深刻度
基本値: 9.8 (緊急) [NVD値]
  • 攻撃元区分: ネットワーク
  • 攻撃条件の複雑さ: 低
  • 攻撃に必要な特権レベル: 不要
  • 利用者の関与: 不要
  • 影響の想定範囲: 変更なし
  • 機密性への影響(C): 高
  • 完全性への影響(I): 高
  • 可用性への影響(A): 高
影響を受けるシステム


The PHP Group
  • FrankenPHP 1.11.2 未満

本脆弱性の影響を受ける製品の詳細については、ベンダ情報および参考情報をご確認ください。
想定される影響

当該ソフトウェアが扱う全ての情報が外部に漏れる可能性があります。
また、当該ソフトウェアが扱う全ての情報が書き換えられる可能性があります。
さらに、当該ソフトウェアが完全に停止する可能性があります。
そして、この脆弱性を悪用した攻撃の影響は、他のソフトウェアには及びません。
対策

正式な対策が公開されています。ベンダ情報を参照して適切な対策を実施してください。
ベンダ情報

GitHub
CWEによる脆弱性タイプ一覧  CWEとは?

  1. 不適切な動作順序 (正規化前の検証)(CWE-180) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-24895
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-24895
  2. 関連文書 : Release v1.11.2  php/frankenphp  GitHub
  3. 関連文書 : fix: path confusion via unicode casing in CGI path splitting  php/frankenphp@04fdc0c  GitHub
更新履歴

  • [2026年02月24日]
      掲載