криптография — это пакет, предназначенный для предоставления разработчикам Python криптографических примитивов и рецептов. До версии 46.0.5 функции public_key_from_numbers (или EllipticCurvePublicNumbers.public_key()), EllipticCurvePublicNumbers.public_key(), load_der_public_key() и load_pem_public_key() не проверяют принадлежность точки к ожидаемой подгруппе кривой простого порядка. Эта недостающая проверка позволяет злоумышленнику предоставить точку открытого ключа P из подгруппы небольшого порядка.
Это может привести к проблемам безопасности в различных ситуациях, таких как наиболее часто используемая проверка подписи (ECDSA) и согласование общего ключа (ECDH). Когда жертва вычисляет общий секрет как S = [victim_private_key]P через ECDH, это приводит к утечке информации о моде «жертва_частного_ключа» (small_subgroup_order). Для кривых с кофактором > 1 это показывает наименее значимые биты закрытого ключа.
Когда эти слабые открытые ключи используются в ECDSA, в небольшой подгруппе легко подделать подписи. Это влияет только на кривые SECT. Эта уязвимость исправлена в версии 46.0.5.
Показать оригинальное описание (EN)
cryptography is a package designed to expose cryptographic primitives and recipes to Python developers. Prior to 46.0.5, the public_key_from_numbers (or EllipticCurvePublicNumbers.public_key()), EllipticCurvePublicNumbers.public_key(), load_der_public_key() and load_pem_public_key() functions do not verify that the point belongs to the expected prime-order subgroup of the curve. This missing validation allows an attacker to provide a public key point P from a small-order subgroup. This can lead to security issues in various situations, such as the most commonly used signature verification (ECDSA) and shared key negotiation (ECDH). When the victim computes the shared secret as S = [victim_private_key]P via ECDH, this leaks information about victim_private_key mod (small_subgroup_order). For curves with cofactor > 1, this reveals the least significant bits of the private key. When these weak public keys are used in ECDSA , it's easy to forge signatures on the small subgroup. Only SECT curves are impacted by this. This vulnerability is fixed in 46.0.5.
Характеристики атаки
Последствия
Строка CVSS v4.0