【活用ガイド】

JVNDB-2026-015093

Project JupyterのJupyter Serverにおけるアンカーのない正規表現に関する脆弱性

概要

Jupyter ServerはJupyterウェブアプリケーションのバックエンドです。バージョン2.17.0以前では、Originヘッダーの検証にPythonのre.match()を使用して、allow_origin_pat設定値と照合していました。しかしre.match()は文字列の先頭のみをアンカーとして完全一致を要求しないため、信頼されたドメイン(例:trusted.example.com)のみをマッチさせるつもりのパターンでも、そのドメインで始まり追加の文字列が続く起源(例:trusted.example.com.evil.com)にもマッチしてしまいます。攻撃者がそのようなドメインを制御している場合、CORSの起源制限を回避して、信頼されていないサイトからJupyter Server APIへのクロスオリジンリクエストを行うことが可能になります。この問題はバージョン2.18.0で修正されました。
CVSS による深刻度 (CVSS とは?)

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


Project Jupyter
  • Jupyter Server 2.18.0 未満

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

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

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

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

  1. アンカーのない正規表現(CWE-777) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-40110
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-40110
  2. 関連文書 : Move check origin into a util function and add it to websocket (#1630)  jupyter-server/jupyter_server@49b3439  GitHub
  3. 関連文書 : Fix allow_origin_pat property to properly parse regex by havok2063  Pull Request #603  jupyter-server/jupyter_server  GitHub
  4. 関連文書 : Fix allow_origin_pat to do full matching instead of prefix matching  jupyter-server/jupyter_server@057869a  GitHub
更新履歴

  • [2026年05月12日]
      掲載