CVE-2026-7846 Langchain-ChatchatのTOCTOU脆弱性によるローカルネットワーク攻撃リスクとAI Security対策手順

結論
- 危険度: Low (CVSS 2.6)
- 対象: langchain-chatchat <= 0.3.1.3
- 修正: ベンダーアドバイザリ参照
- 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-12 | 本記事は公式情報をもとに作成しています。最新情報はベンダー公式アドバイザリを必ずご確認ください。
| STEP | やること | かかる目安 |
|---|---|---|
| STEP 1 | 何が起きているか理解する | 3分 |
| STEP 2 | 急ぎ対応すべきか判断する | 3分 |
| STEP 3 | 自分の環境が対象か確認する | 5分 |
| STEP 4 | 修正を適用する | 環境による |
| STEP 5 | 修正されたことを確認する | 3分 |
STEP 1: 何が起きているか
一言でいうと
CVE-2026-7846はlangchain-chatchat 0.3.1.3以下にある脆弱性で、攻撃者がローカルネットワークからファイル名を悪用して不正行為を仕掛けられます。LLMゲートウェイを運用している方は優先的に対応してください。
やさしく説明すると
この脆弱性は「荷物の宛先ラベルが検査中にすり替わり、違う場所に勝手に届く」ようなものです。ファイルアップロードを扱うAPIで、ファイル名が安全に扱われていません。ローカルネットワークにアクセスできる人が、複雑な手順を踏んで悪用できますが、攻撃は実行が難しいため敷居は高いです。
技術的な原因
原因は競合状態(タイム・オブ・チェック・トゥ・タイム・オブ・ユース:TOCTOU)にあります。これは日本語で「検査と使用の間に時間差がある処理」です。攻撃者はこのタイミングのズレを利用して、意図しないファイル名を処理させます。CWE-362(競合状態)およびCWE-367(タイム・オブ・チェック・トゥ・タイム・オブ・ユースの誤操作)が該当します。
影響を受けると何が困るか
- ファイルの不正上書きや不正利用によるシステム動作の異常
- LLMコンテキストやファイル経由の他の重要情報が間接的に漏洩する恐れ
- Agentフレームワークに組み込んだファイルアップロードAPIを悪用され、プロンプトインジェクションやエージェント乗っ取りの足掛かりになる可能性
- LLMゲートウェイやAPI経由での不正アクセスによるシステム障害やコスト増加のリスク
- バイブコーダーでのコード補完・ファイル連携機能に悪影響が及ぶ可能性
もっと詳しく調べたい人へ — 公式情報源マップ
本記事は以下の公式・準公式の情報源から内容を集約しています。一次情報を確認したい場合や英語で詳細を読みたい場合は、各リンクから直接アクセスできます。
| カテゴリ | 情報源 | 言語 | 何が分かるか | リンク |
|---|---|---|---|---|
| 総合 | 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スコアは2.6(低)であり、実務的には即対応が必須でない軽度の脆弱性です。
- EPSSスコアは0.02%と非常に低く、直近30日での悪用予測もほぼありません。
- ランサムウェアによる悪用報告はありません。
- 公開PoC(実証コード)は出ていません。
- 攻撃にはローカルネットワークアクセスが必要で、攻撃複雑度も高いため、容易に悪用されません。
誰が動くべきか
- Langchain-Chatchatを利用しファイルアップロードAPIを運用しているエンジニア
- LLM Gatewayの運用チーム(Langchain系含む)
- Agentフレームワーク開発者(LangChainやAgentic等)
- バイブコーダー開発者(Cursor、Cline、Copilot等の利用者)
STEP 3: 自分の環境が対象か確認する
影響を受けるバージョン
| 製品 | 脆弱なバージョン範囲 | 修正版 |
|---|---|---|
| langchain-chatchat | 0.3.1.3以下 | ベンダーアドバイザリ参照(未公開) |
バージョン確認コマンド
Python (pip)
pip show langchain-chatchat
出力例:
Name: langchain-chatchat
Version: 0.3.1.3
Summary: Langchain Chatchat Library
判定: バージョンが 0.3.1.3 以下なら脆弱です
Python (pip list+grep)
pip list | grep langchain-chatchat
出力例:
langchain-chatchat 0.3.1.3
判定: 0.3.1.3 以下だと対象
設定確認
本脆弱性は設定依存ではなく、対象バージョンのlangchain-chatchatのOpenAI-Compatible File Upload APIに組み込まれた競合状態の問題です。設定変更での緩和はできません。
Nucleiテンプレートでの検出
本件の公開Nucleiテンプレートは存在しません。必ずバージョン確認で検出してください。
STEP 4: 修正を適用する
パッチ適用
ベンダーは現時点で修正版の公開をしていないため、アップグレードはベンダー公式アドバイザリを随時確認してください。
修正版がリリースされ次第、以下のようにpipでアップグレードを実施します。
Python (pip)
pip install --upgrade langchain-chatchat
判定: 最新版のバージョンが 0.3.1.4以上なら安全です
注意: パッチ適用前に必ずバックアップを取得してください。また、ステージング環境で動作検証を行い、本番環境でのダウンタイム計画を立ててください。
パッチ即時適用ができない場合の暫定対応
公式の暫定対応は提示されていません。ローカルネットワークからのアクセス制御やWAFの設定強化を検討してください。
STEP 5: 修正されたことを確認する
STEP 3で実施したバージョン確認コマンドを修正後に再度実行する必要があります。
期待される出力
Python (pip)
pip show langchain-chatchat
出力例:
Name: langchain-chatchat
Version: 0.3.1.4
Summary: Langchain Chatchat Library
判定: バージョンが 0.3.1.4 以上ならOK
Python (pip list+grep)
pip list | grep langchain-chatchat
出力例:
langchain-chatchat 0.3.1.4
判定: 0.3.1.4 以上なら安全
追加で確認すべきこと
- ログに不審なファイルアクセスやリクエストの履歴がないか監視してください
- アップグレード後にAPIの動作テストを実施し、正常に機能していることを確認してください
補足: 悪用観測状況
現時点でランサムウェアや他の攻撃グループによる悪用は報告されていません。公開PoCも存在せず、難易度が高い脆弱性として分類されています。引き続き公式アドバイザリやGitHubの動向を注視してください。
補足: CVSSメトリクス詳細
- AV(攻撃元): ADJACENT_NETWORK(隣接ネットワークからの攻撃)
- AC(攻撃複雑度): HIGH(攻撃成功に高度な操作が必要)
- PR(必要権限): LOW(低い権限で攻撃可能)
- UI(ユーザ操作): NONE(ユーザ操作不要)
- S(スコープ): UNCHANGED(影響範囲は同一のまま)
- C(機密性影響): NONE(機密情報の漏洩はなし)
- I(完全性影響): LOW(データの改ざん可能性あり)
- A(可用性影響): NONE(システム停止などはなし)
よくある質問(FAQ)
Q. このCVEに対応するために最低限すべきことは何ですか?
A. まずSTEP 3のバージョン確認を実施してください。脆弱バージョンなら、STEP 4でベンダー公開の修正を適用し、STEP 5でバージョンと動作を検証してください。
Q. パッチが適用できない場合、どうすればよいですか?
A. 公式の暫定対応はありませんが、ローカルネットワークのアクセス制御やファイアウォール強化などでリスク低減を検討してください。
Q. 既に攻撃を受けているか確認する方法はありますか?
A. 公式のIOC(侵入インディケータ)はありませんが、ログで不審なファイルアクセスやAPI利用を監視してください。
Q. なぜEPSSスコアが重要なのですか?
A. CVSSは脆弱性の理論的な深刻度を示しますが、EPSSは実際に悪用される見込みを示します。両方を確認すると優先度判断が明確になります。
Q. このCVEと類似の脆弱性は他にもありますか?
A. 同じCWE-362とCWE-367に分類される競合状態やTOCTOU関連の脆弱性は他のAI関連APIでも起こりえます。類似リスクは注意が必要です。
参考文献
関連トピック・タグから探す
本記事に関連するキーワードから、他のAIセキュリティ記事を探せます。
