【活用ガイド】

JVNDB-2026-009587

Locutusにおけるオブジェクトプロトタイプ属性の不適切に制御された変更に関する脆弱性

概要

Locutusは教育目的で他のプログラミング言語の標準ライブラリをJavaScriptに持ち込むものです。バージョン3.0.25以前の`locutus/php/var/unserialize`にある`unserialize()`関数は、`__proto__`キーをフィルタリングせずに角括弧記法を使って逆シリアライズされたキーをプレインオブジェクトに割り当てます。PHPのシリアライズされたペイロードに`__proto__`が配列またはオブジェクトのキーとして含まれている場合、JavaScriptの`__proto__`セッターが呼び出され、逆シリアライズされたオブジェクトのプロトタイプが攻撃者制御の内容に置き換えられます。これにより、プロパティの注入やin演算子による注入プロパティの伝播、および組み込みメソッドの上書きによるサービス拒否が可能となります。以前報告された`parse_str`のプロトタイプ汚染(GHSA-f98m-q3hr-p5wq、GHSA-rxrv-835q-v5mh)とは異なり、`unserialize`は別の関数で、緩和策は適用されていません。この問題はバージョン3.0.25で修正されました。
CVSS による深刻度 (CVSS とは?)

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


Locutus
  • Locutus 3.0.25 未満

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

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

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

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

  1. オブジェクトプロトタイプ属性の不適切に制御された変更 (プロトタイプの汚染)(CWE-1321) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-33993
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-33993
  2. 関連文書 : fix: harden php prototype pollution sinks by kvz  Pull Request #597  locutusjs/locutus  GitHub
  3. 関連文書 : Release v3.0.25  locutusjs/locutus  GitHub
  4. 関連文書 : fix: harden php prototype pollution sinks (#597)  locutusjs/locutus@345a621  GitHub
更新履歴

  • [2026年04月02日]
      掲載