【活用ガイド】

JVNDB-2026-005461

Koa.jsのKoaにおける入力確認に関する脆弱性

概要

KoaはES2017の非同期関数を使用するNode.js向けのミドルウェアです。バージョン3.1.2および2.16.4以前のKoaの`ctx.hostname` APIはHTTP Hostヘッダーを単純に解析し、最初のコロンの前までのすべての文字を抽出しますが、入力がRFC 3986のホスト名構文に準拠しているかどうかを検証しません。`@`記号を含む不正なHostヘッダーを受信した場合、`ctx.hostname`は攻撃者が制御する`evil[.]com`という値を返します。URL生成、パスワードリセットリンク、メール検証URL、またはルーティング判断のために`ctx.hostname`を使用するアプリケーションは、Hostヘッダーインジェクション攻撃に対して脆弱である可能性があります。バージョン3.1.2および2.16.4でこの問題は修正されました。
CVSS による深刻度 (CVSS とは?)

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


Koa.js
  • Koa 2.16.14 未満
  • Koa 3.0.0 以上 3.1.2 未満

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

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

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

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

  1. 不適切な入力確認(CWE-20) [その他]
  2. 情報不足(CWE-noinfo) [NVD評価]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-27959
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-27959
  2. 関連文書 : Merge commit from fork  koajs/koa@b76ddc0  GitHub
  3. 関連文書 : Merge commit from fork  koajs/koa@55ab9ba  GitHub
更新履歴

  • [2026年03月02日]
      掲載