【活用ガイド】

JVNDB-2026-009865

Jon Schlinkertのpicomatchにおける非効率的な正規表現の複雑さに関する脆弱性

概要

PicomatchはJavaScriptで書かれたグロブマッチャーです。バージョン4.0.4、3.0.2、2.3.2より前のバージョンには、細工されたextglobパターンを処理する際に正規表現拒否サービス攻撃(ReDoS)の脆弱性があります。特に`+()`や`*()`といったextglobの量指定子を使用し、重複する選択肢や入れ子になったextglobと組み合わせた場合、一部のパターンは正規表現にコンパイルされ、非マッチ入力で壊滅的なバックトラッキングを引き起こす可能性があります。信頼できないユーザーが生成したグロブパターンを`picomatch`に渡してコンパイルやマッチングを行うアプリケーションが影響を受けます。その場合、攻撃者が過剰なCPU消費を引き起こし、Node.jsのイベントループをブロックしてサービス拒否に至らせる可能性があります。開発者が管理する信頼されたグロブパターンのみを使用するアプリケーションでは、この問題がセキュリティ上の大きなリスクになる可能性は低いです。この問題はpicomatchの4.0.4、3.0.2、2.3.2で修正されています。ユーザーはサポート対象のリリースラインに応じてこれらのバージョン以降にアップグレードする必要があります。すぐにアップグレードできない場合は、信頼できないグロブパターンを`picomatch`に渡すことを避けてください。対応策として、信頼できないパターンに対してextglobサポートを`noextglob: true`で無効化すること、ネストしたextglobや`+()`や`*()`などの量指定子を含むパターンを拒否またはサニタイズすること、許可されるパターン構文の厳格なホワイトリストを施行すること、制限された時間とリソースの中で隔離されたワーカーや別プロセスでマッチングを実行すること、グロブパターンを受け入れるエンドポイントでアプリケーションレベルのリクエスト制限や入力検証を適用することなどがあります。
CVSS による深刻度 (CVSS とは?)

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


Jon Schlinkert
  • picomatch 2.3.2 未満
  • picomatch 3.0.0 以上 3.0.2 未満
  • picomatch 4.0.0 以上 4.0.4 未満

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

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

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

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

  1. 非効率的な正規表現の複雑さ(CWE-1333) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-33671
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-33671
  2. 関連文書 : Merge commit from fork  micromatch/picomatch@5eceecd  GitHub
更新履歴

  • [2026年04月03日]
      掲載