MENU

【高】CVE-2026-47101 LiteLLMの認証済みユーザーによる権限エスカレーション脆弱性とAPIキー管理不備対策ガイド

  • URLをコピーしました!

AI Security速報をXで配信しています!!

AI/LLM関連の脆弱性、PoC、KEV追加などの更新情報を見逃したくない方は、Xをフォローしてねー!

Xでフォローする

本記事は公開時点の情報をもとにした速報記事です。内容が更新される場合があるため、必要に応じてベンダー公式情報や一次情報もあわせて確認してください。

目次

結論

  • 危険度: High (CVSS 8.8)
  • 対象: (詳細はベンダーアドバイザリ参照)
  • 修正: ベンダーアドバイザリ参照
  • KEV: No (NVD Critical由来。CISA KEVには未登録)
タイトルの緊急度プレフィックス(【至急】【最重大】等)の意味
表記 条件 意味 対応目安
【至急/ランサム悪用】 CISA KEV登録 + ランサムウェア悪用観測 ランサムグループが現在進行形で悪用 本日中に対応開始
【至急/重大】 CISA KEV登録 + CVSS 9.0以上 実世界で攻撃観測あり + スコア極めて高い 本日中に対応開始
【重大/KEV登録】 CISA KEV登録(CVSS低またはNVD未反映) 実世界で攻撃観測あり 数日以内
【最重大】 CVSS 9.5以上(KEV未登録) 理論上の危険度ほぼ満点、攻撃観測はまだない 1週間以内に対応計画
【重大】 CVSS 9.0〜9.4(KEV未登録) Critical帯の理論的高リスク 1〜2週間以内
【高】 CVSS 7.0〜8.9(KEV未登録) High帯のリスク 計画的に対応
(プレフィックスなし) CVSS 7.0未満 Medium以下のリスク 通常メンテで対応

「至急」と「最重大」の違い: 「至急」は CISA(米国政府機関)が 実際に悪用を観測した CVEに付与されます。「最重大」は CVSS スコア上は最高峰だが、まだ悪用観測がない ものです。同じCVSS 9.8でもKEV登録の有無で扱いが変わります。

最終更新: 2026-05-21 | 本記事は公式情報をもとに作成しています。最新情報はベンダー公式アドバイザリを必ずご確認ください。

STEP やること かかる目安
STEP 1 何が起きているか理解する 3分
STEP 2 急ぎ対応すべきか判断する 3分
STEP 3 自分の環境が対象か確認する 5分
STEP 4 修正を適用する 環境による
STEP 5 修正されたことを確認する 5分

STEP 1: 何が起きているか

一言でいうと

CVE-2026-47101はLiteLLMの脆弱性で、認証済みの内部ユーザーが自分の権限を超えて管理者用APIキーを作成できます。攻撃者はこの脆弱性を利用し、APIの権限検査を回避して特権を乗っ取れます。LLMゲートウェイ運用者にとって最優先対応です。

やさしく説明すると

これは、会社の社内システムの鍵が勝手にコピーされてしまうような問題です。ユーザーは自分の範囲内だけ操作できるはずですが、この脆弱性は「許されていない裏口」も開けてしまいます。つまり、本来は触れない管理者の領域に簡単にアクセスできます。結果、システムの守りが根底から崩れます。

技術的な原因

この脆弱性はCWE-863(アクセス制御の不足)に分類されます。具体的には、LiteLLMがAPIキーを生成する際に、ユーザーが指定したアクセス可能な経路(allowed_routes)を検証しません。これにより、ユーザーの権限外のパスへアクセスするAPIキーが作成可能になります。

初出時は「アクセス制御(Access Control)」や「権限昇格(Privilege Escalation)」という用語を使い説明しましたが、要はシステムの「誰が何にアクセスできるか」というルールの検証が抜けているのが原因です。

影響を受けると何が困るか

  • 管理権限を持つAPIキーの不正作成による権限の完全な乗っ取り
  • LLM Gateway(LiteLLM)におけるロールベースアクセス制御の完全無効化
  • API経由でのモデルや設定の不正変更・改ざん
  • テナント間データ漏洩の危険増大
  • AI駆動開発環境(CursorやClineなど)経由での間接的な脆弱性連鎖のリスク
  • 認証情報や機密情報が管理者権限経由で漏洩する可能性

もっと詳しく調べたい人へ — 公式情報源マップ

本記事は以下の公式・準公式の情報源から内容を集約しています。一次情報を確認したい場合や英語で詳細を読みたい場合は、各リンクから直接アクセスできます。

カテゴリ 情報源 言語 何が分かるか リンク
総合 NVD(米国 NIST) 米国政府の脆弱性データベース。CVSSスコア、影響を受けるCPE、参考リンクの総合ハブ。最も網羅的。 開く
総合 MITRE CVE CVE採番機関の公式記録。CVE記述の「正本」。NVDより記載が簡潔だが一次情報。 開く
総合 JVN iPedia(JPCERT/CC・IPA) 日本のCSIRTが運用する脆弱性対策情報データベース。日本語で概要・対策が読める。掲載がない場合あり。 開く
総合 CISA KEV(悪用観測カタログ) 米国CISAが実際に悪用を確認している脆弱性のカタログ。掲載されていれば最優先で対応。 開く
総合 GitHub Advisory Database OSSパッケージ(npm/pypi/maven/composer/go等)別の脆弱性アドバイザリ。修正PRへのリンクが豊富。 開く
総合 OpenCVE 複数CVEデータベースの集約検索サービス。タイムラインや関連CVEの俯瞰に有用。 開く
Linux Red Hat CVE Red Hat製品(RHEL/CentOS Stream/Rocky/AlmaLinux系)の影響評価とパッチ状況。 開く
Linux Ubuntu Security Ubuntu の影響評価。各Ubuntuバージョン(22.04/24.04等)でのパッチ提供状況が一目で分かる。 開く
Linux Debian Security Tracker Debian の影響評価。stable/testing/sid別のパッチ状況。Debian派生ディストリ利用者向け。 開く
Linux SUSE CVE SUSE Linux Enterprise / openSUSE の影響評価とパッチ状況。 開く
悪用 Exploit Database 公開エクスプロイトのアーカイブ。検出ツールやペネトレーションテストでの参照用。 開く
悪用 Packet Storm Security セキュリティアドバイザリ・エクスプロイトの集約サイト。古めの情報も含む。 開く
悪用 GitHub PoC 検索 GitHubコード検索でCVE IDを直接検索。野良PoCの早期発見に。 開く
悪用 X(Twitter)検索 日英 直近の議論やニュースを観測。In-the-wild悪用の早期検知に有用。 開く
スキャナ Snyk Vulnerability DB パッケージ別の脆弱性詳細と修正バージョン。OSS依存ライブラリ追跡に有用。 開く
スキャナ Tenable(Nessus) Nessusスキャナでの検出プラグイン情報。検出ロジックの参考に。 開く
スキャナ Rapid7(Metasploit/Nexpose) Metasploit悪用モジュール、Nexposeでの検出情報。 開く

掲載しているのは無料でアクセスできる情報源のみです。CVEによっては掲載がないサイトもあります(特にJVN iPediaは日本国内で報告された脆弱性のみ掲載)。

STEP 2: 急ぎ対応すべきか判断する

結論: 高

判断根拠

  • CVSS v3.1スコアは8.8の高リスク。攻撃はネットワーク経由で低複雑度、認証済みユーザーによる操作のみで成功可能です。つまり、内部関係者や認証済みのユーザーであれば悪用が容易です。
  • EPSS(悪用予測スコア)は未提供です。
  • ランサムウェアによる悪用の報告は現在ありません。
  • 公開PoCや攻撃コードの公表も今のところありません。
  • 影響範囲は認証済み内部ユーザーに限定されているため、攻撃条件はやや限定されます。
  • ただし、権限の乗っ取りという重大な問題なので優先的に対応してください。

誰が動くべきか

  • LLM Gateway 運用チーム(特にLiteLLMを利用している場合)
  • Agent フレームワーク開発者(APIキー管理に関わる部分)
  • MLインフラチーム(権限管理の監査者)
  • バイブコーダー開発者(Cursor/Cline等からのAPI連携がある場合)
  • セキュリティ運用チーム(SecOps/SRE)

STEP 3: 自分の環境が対象か確認する

影響を受けるバージョン

製品 脆弱なバージョン範囲 修正版
LiteLLM 1.83.13以前 1.83.14以降

バージョン確認コマンド

Python (pip)

pip show litellm

出力例:

Name: litellm
Version: 1.83.13
Summary: LiteLLM - A lightweight LLM proxy server
...

判定: バージョンが 1.83.13 以下なら脆弱、1.83.14 以上なら安全です。

Python (pip list)

pip list | grep litellm

出力例:

litellm          1.83.13

判定: バージョンが 1.83.13 以下なら要アップデートです。

設定確認

この脆弱性は設定に依存しません。バージョンが脆弱範囲内であれば影響を受けます。

Nucleiテンプレートでの検出

現時点で公開Nucleiテンプレートは存在しません。バージョン確認で対応してください。

STEP 4: 修正を適用する

パッチ適用

Python環境 (pipによるアップグレード)

pip install --upgrade litellm

判定: アップグレード後、バージョンが 1.83.14 以上になれば安全です。

注意: パッチ適用前に必ず設定やデータのバックアップを取得してください。アップグレードはステージング環境で十分に検証した後、本番環境へ適用してください。ダウンタイムが発生する可能性も考慮してください。

パッチ即時適用ができない場合の暫定対応

公式の暫定対応は提示されていません。ネットワークレベルでアクセスを制限するか、認証済み内部ユーザーの権限管理を厳格に行うことが実務的な緩和策となります。

STEP 5: 修正されたことを確認する

STEP 3で実行したバージョン確認コマンドを再度実施してください。

期待される出力

Python (pip)

pip show litellm

出力例:

Name: litellm
Version: 1.83.14
Summary: LiteLLM - A lightweight LLM proxy server
...

判定: バージョンが 1.83.14 以上ならOK

Python (pip list)

pip list | grep litellm

出力例:

litellm          1.83.14

判定: バージョンが 1.83.14 以上なら安全です。

追加で確認すべきこと

修正後はログに不審なAPIキー作成やアクセス履歴がないか監視してください。公開Nucleiテンプレートが未提供のためスキャナ等は使えませんが、ユーザー操作ログから異常検知が重要です。

補足: 悪用観測状況

現状、CVE-2026-47101の悪用は報告されていません。GitHub上に公開されたPoCコードも見つかっていません。ランサムウェアグループによる悪用の情報もありません。公開された情報からは悪用事例はまだ確認されていない状態です。

補足: CVSSメトリクス詳細

  • AV (攻撃元): NETWORK – 攻撃者はネットワーク経由で攻撃可能
  • AC (攻撃複雑度): LOW – 攻撃は容易で特別な条件を必要としない
  • PR (必要権限): LOW – 認証済みユーザー権限があれば攻撃可能
  • UI (ユーザー操作): NONE – 攻撃に対象の操作は不要
  • S (範囲): UNCHANGED – 影響範囲は変わらず
  • C (機密性影響): HIGH – 機密情報が漏洩しうる
  • I (完全性影響): HIGH – データや権限の改ざんが可能
  • A (可用性影響): HIGH – システムの停止や障害を招く可能性

よくある質問(FAQ)

Q. このCVEに対応するために最低限すべきことは何ですか?

A. まずSTEP 3で自分の環境のLiteLLMのバージョンを確認し、脆弱であればSTEP 4の修正バージョン1.83.14以降へアップグレードしてください。その後STEP 5で修正を確認します。

Q. パッチが適用できない場合、どうすればよいですか?

A. 公式の暫定対応はありませんが、内部ユーザーの管理を強化し、不要なアクセスを防ぐネットワーク制限や権限監査を強化してください。

Q. 既に攻撃を受けているか確認する方法はありますか?

A. APIキーの不正作成ログや異常な管理者アクセスの監査ログを確認してください。公開されたPoCはないため、攻撃の痕跡をログから探すのが基本です。

Q. なぜEPSSスコアが重要なのですか?

A. CVSSは脆弱性の理論的リスクを示し、EPSSは実際に悪用が起こる確率を予測します。両方を見ることで優先順位の判断がより正確になります。

Q. このCVEと類似の脆弱性は他にもありますか?

A. CWE-863(アクセス制御不足)に属する脆弱性は他にも存在します。APIキー管理やロールベースアクセス制御に関連する脆弱性は継続して注意が必要です。

参考文献

本記事に関連するキーワードから、他のAIセキュリティ記事を探せます。

2026-05-29 追記

本記事の公開後、以下の重要な変化が確認されました(公開からの経過: 6日)。

項目 公開時点 2026-05-29時点 変化の意味
結論ボックスの対象範囲が未記入 (詳細はベンダーアドバイザリ参照) cpe:2.3:a:litellm:litellm:*:*:*:*:*:*:*:* <1.83.14 公開時は具体的な対象範囲が不明だったが、現在は確定済み(記事生成時の凡ミス補正)
結論ボックスの修正バージョンが未記入 ベンダーアドバイザリ参照 3件のパッチリンクあり(https://github.com/BerriAI/litellm/commit/2220f3076ac89bd2a2e3439acf57dcfbec2434c9 等) 公開時は修正版情報が結論ボックスにテンプレ文字列のまま残っていた。現在は具体的な修正版が判明(記事生成時の凡ミス補正)

結論ボックスの対象範囲が未記入

公開当初は、LiteLLM製品のどのバージョンが脆弱性の対象となるかが「(詳細はベンダーアドバイザリ参照)」の表記のまま明記されていませんでした。しかし現在、「cpe:2.3:a:litellm:litellm:*:*:*:*:*:*:*:* <1.83.14」により、1.83.14未満全てが影響範囲であることがはっきり示されました。自組織が運用するバージョンがこの範囲内か必ず確認してください。対象が確定した今、該当バージョンを利用中の環境では早急なアップデート等の対策が急務です。

結論ボックスの修正バージョンが未記入

記事公開時には修正済みバージョンの情報も「ベンダーアドバイザリ参照」のテンプレ表記のままとなっていましたが、現時点で「3件のパッチリンクあり(https://github.com/BerriAI/litellm/commit/2220f3076ac89bd2a2e3439acf57dcfbec2434c9 等)」と、具体的な修正版詳細が明らかになりました。このため、どのコミットで修正されたか、パッチ内容も直接確認できるようになっています。運用者はリンクの内容を確認し、自環境への反映可否を検討するとともに、修正バージョンへの移行やバックポート対応作業を計画的に実施することを推奨します。

2026-06-05 追記

本記事の公開後、以下の重要な変化が確認されました(公開からの経過: 13日)。

項目 公開時点 2026-06-05時点 変化の意味
結論ボックスの対象範囲が未記入 (詳細はベンダーアドバイザリ参照) cpe:2.3:a:litellm:litellm:*:*:*:*:*:*:*:* <1.83.14 公開時は具体的な対象範囲が不明だったが、現在は確定済み(記事生成時の凡ミス補正)
結論ボックスの修正バージョンが未記入 ベンダーアドバイザリ参照 3件のパッチリンクあり(https://github.com/BerriAI/litellm/commit/2220f3076ac89bd2a2e3439acf57dcfbec2434c9 等) 公開時は修正版情報が結論ボックスにテンプレ文字列のまま残っていた。現在は具体的な修正版が判明(記事生成時の凡ミス補正)

結論ボックスの対象範囲が未記入

公開当初は、LiteLLMの脆弱な対象バージョンが「(詳細はベンダーアドバイザリ参照)」と未記載のままでしたが、今回「cpe:2.3:a:litellm:litellm:*:*:*:*:*:*:*:* <1.83.14」と正確な範囲が判明・反映されました。これにより、利用者はどのバージョンまでが影響を受けるかを明確に把握できるようになりました。運用担当者は自組織のLiteLLMバージョンが該当していないか、本情報をもとに再確認することを強く推奨します。

結論ボックスの修正バージョンが未記入

記事初出時は修正版(パッチ)について「ベンダーアドバイザリ参照」と表示していましたが、今回「3件のパッチリンクあり(https://github.com/BerriAI/litellm/commit/2220f3076ac89bd2a2e3439acf57dcfbec2434c9 等)」のように、具体的な修正コミットが示される形に是正されました。これにより管理者や保守担当者は、修正版取得元や改修内容をダイレクトに追跡可能となります。対応にあたっては提示されたパッチリンクを参照し、必ず最新版へのアップデート、または該当パッチの適用を実施してください。

AI Security速報を継続配信しています!!

AI/LLM関連の脆弱性、PoC、KEV追加、海外アドバイザリなどを X で配信してるので、ぜひフォローをお願いします!

@ai_sec_news_256 をフォロー

この記事が気に入ったら
フォローしてね!

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!
目次