PyCryptodome RSA шифрование

Я пытаюсь использовать пример шифрования файла pycryptodome с ключом RSA. Пример выглядит следующим образом

from Crypto.PublicKey import RSA
from Crypto.Random import get_random_bytes
from Crypto.Cipher import AES, PKCS1_OAEP

file_out = open("encrypted_data.bin", "wb")

recipient_key = RSA.import_key(open("receiver.pem").read())
session_key = get_random_bytes(16)

# Encrypt the session key with the public RSA key
cipher_rsa = PKCS1_OAEP.new(recipient_key)
file_out.write(cipher_rsa.encrypt(session_key))

# Encrypt the data with the AES session key
cipher_aes = AES.new(session_key, AES.MODE_EAX)
ciphertext, tag = cipher_aes.encrypt_and_digest(data)
[ file_out.write(x) for x in (cipher.nonce, tag, ciphertext) ]

И ошибка, которую я получаю,

AttributeError: модуль "Crypto.PublicKey.RSA" не имеет атрибута "import_key"

Я нашел другой поток, в котором эта ошибка была идентифицирована как проблема с версией pyCrypto, но я пытаюсь использовать PyCryptodome, и у меня действительно последняя версия.

1 ответ

Метод import_key был добавлен в PyCryptodome v3.4. Если вы получаете это сообщение об ошибке, это означает, что вы на самом деле используете PyCrypto или более старую версию PyCryptodome.

Другие вопросы по тегам