【活用ガイド】

JVNDB-2026-012081

phpseclibにおけるタイミングの違いに起因する情報漏えいに関する脆弱性

概要

phpseclibはPHPの安全な通信ライブラリです。バージョン3.0.51、2.0.53、および1.0.28より前のphpseclib\Net\SSH2::get_binary_packet()は、受信したSSHパケットのHMACをローカルで計算したHMACと比較する際にPHPの!=演算子を使用していました。PHPにおける同じ長さのバイナリ文字列に対する!=演算子はmemcmp()を使用し、最初に異なるバイトで処理を中断します。これは実際には変動時間比較(CWE-208)に該当し、スケーリングベンチマークで証明されています。この脆弱性はバージョン3.0.51、2.0.53、および1.0.28で修正されています。
CVSS による深刻度 (CVSS とは?)

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


phpseclib
  • phpseclib 1.0.27 およびそれ以前
  • phpseclib 2.0.0 以上 2.0.53 未満
  • phpseclib 3.0.0 以上 3.0.51 未満

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

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

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

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

  1. タイミングの違いに起因する情報漏えい(CWE-208) [その他]
共通脆弱性識別子(CVE)  CVEとは?

  1. CVE-2026-40194
参考情報

  1. National Vulnerability Database (NVD) : CVE-2026-40194
  2. 関連文書 : Release 1.0.28  phpseclib/phpseclib  GitHub
  3. 関連文書 : Release 2.0.53  phpseclib/phpseclib  GitHub
  4. 関連文書 : Release 3.0.51  phpseclib/phpseclib  GitHub
  5. 関連文書 : SSH2: use constant time string comparison in get_binary_packet():  phpseclib/phpseclib@ffe48b6  GitHub
更新履歴

  • [2026年04月23日]
      掲載