【活用ガイド】

JVNDB-2026-009852

opensc projectのopenscにおけるバッファオーバーリードの脆弱性

概要

OpenSCはオープンソースのスマートカードツールおよびミドルウェアです。バージョン0.27.0以前では、sc_compacttlv_find_tag関数は特定のタグをコンパクトTLVバッファ内で検索します。コンパクトTLVでは、1バイトでタグ(上位ニブル)と値の長さ(下位ニブル)がエンコードされます。たとえば、1バイトのバッファ{0x0A}の場合、エンコードされた要素はタグが0、長さが10であると示しますが、値のバイトは続きません。検索タグ0x00でsc_compacttlv_find_tagを呼び出すと、指定された値の長さが残りのバッファに収まるかどうかを確認せずに、buf+1と等しいポインタが返され、outlen=10となります。sc_compacttlv_find_tagに信頼できないデータ(カードやファイルから読み取られた場合など)が提供されると、攻撃者がアウトオブバウンズのポインタを返すように影響を与え、後続のコードがそのポインタを参照する際にメモリ破損を引き起こす可能性があります。この問題はバージョン0.27.0で修正されました。
CVSS による深刻度 (CVSS とは?)

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


opensc project
  • opensc 0.27.0 未満

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

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

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

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

  1. バッファオーバーリード(CWE-126) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2025-66038
参考情報

  1. National Vulnerability Database (NVD) : CVE-2025-66038
  2. 関連文書 : idprime: fix pin padding for SafeNet eToken 5100 [eToken 5110 SC]  OpenSC/OpenSC@6db171b  GitHub
更新履歴

  • [2026年04月03日]
      掲載