【活用ガイド】

JVNDB-2026-010626

gRPCにおける認可に関する脆弱性

概要

gRPC-GoはgRPCのGo言語による実装です。バージョン1.79.3より前のものには、HTTP/2の`:path`擬似ヘッダーの不適切な入力検証に起因する認可回避の脆弱性が存在します。gRPC-Goサーバーでは、ルーティングロジックが寛容すぎたため、必須の先頭スラッシュが省略された`:path`(例: `/Service/Method`ではなく`Service/Method`)を含むリクエストを受け入れていました。サーバーはこれらのリクエストを正しいハンドラーにルーティングしましたが、認可インターセプター(公式の`grpc/authz`パッケージを含む)は正規化されていない生のパス文字列を評価していました。その結果、先頭がスラッシュ(`/`)で始まる正規パスを使用する「拒否」ルールがマッチせず、フォールバックの「許可」ルールが存在する場合はポリシーを回避してしまいました。これは、`google.golang.org/grpc/authz`の公式RBAC実装や、`info.FullMethod`または`grpc.Method(ctx)`に依存するカスタムインターセプターなど、パスベースの認可インターセプターを使用し、かつ正規パスに対する特定の「拒否」ルールを含み、他の要求をフォールバックで許可するセキュリティポリシーを持つgRPC-Goサーバーに影響を与えます。この脆弱性は、攻撃者が生のHTTP/2フレームで不正な`:path`ヘッダーを直接gRPCサーバーに送信することで悪用できます。バージョン1.79.3の修正では、先頭スラッシュで始まらない`:path`を持つリクエストは即座に`codes.Unimplemented`エラーで拒否し、認可インターセプターやハンドラーに正規化されていないパス文字列が到達するのを防いでいます。アップグレードが最も安全かつ推奨される対策ですが、次の方法でも緩和可能です。検証用インターセプターの使用(推奨される緩和策)、インフラレベルでの正規化、及びポリシーの強化です。
CVSS による深刻度 (CVSS とは?)

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


gRPC
  • gRPC 1.79.3 未満

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

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

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

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

  1. 不適切な認可(CWE-285) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-33186
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-33186
更新履歴

  • [2026年04月13日]
      掲載