【活用ガイド】

JVNDB-2026-011025

digitalbazaarのforgeにおけるデジタル署名の検証に関する脆弱性

概要

Forge(別名 `node-forge`)は、JavaScriptで実装されたTransport Layer Securityのネイティブ実装です。バージョン1.4.0より前では、Ed25519署名検証がスカラーSが群の位数で剰余をとっていない偽造された非正規署名(`S = L`)を受け入れていました。有効な署名とその`S + L`バリアントの両方がforgeで検証される一方、Node.jsの`crypto.verify`(OpenSSLバックエンド)は仕様で定義されている通り`S + L`バリアントを拒否します。この種の署名変更可能性は、実際に認証や認可ロジックを回避するために悪用されています。署名の一意性を前提としたアプリケーション(例えば、署名バイトによる重複除去、リプレイトラッキング、署名済みオブジェクトの正規化チェック)は回避される可能性があります。バージョン1.4.0でこの問題は修正されました。
CVSS による深刻度 (CVSS とは?)

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


digitalbazaar
  • forge 1.3.3 およびそれ以前

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

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

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

GitHub インターネット技術タスクフォース (IETF)
CWEによる脆弱性タイプ一覧  CWEとは?

  1. デジタル署名の不適切な検証(CWE-347) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-33895
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-33895
  2. 関連文書 : Add canonical signature scaler check for S < L.  digitalbazaar/forge@bdecf11  GitHub
更新履歴

  • [2026年04月15日]
      掲載