Python3 Cryptodome - как расшифровать pem? - PullRequest
0 голосов
/ 05 ноября 2018

Я пытаюсь расшифровать свой закрытый ключ в python, используя cryptodome. Под raw_cipher_data находится мой пароль для шифрования закрытого ключа. Но я получаю сообщение об ошибке «ValueError: PEM зашифрован, но пароль не доступен»

МОЙ ИМПОРТ

from Cryptodome.Signature import PKCS1_v1_5
from Cryptodome.Hash import SHA
from Cryptodome.PublicKey import RSA
from base64 import b64decode

код

rsa_key = RSA.importKey(open('pem file location', "rb").read())
verifier = PKCS1_v1_5.new(rsa_key)
raw_cipher_data = b64decode(<your cipher data>)
phn = rsa_key.decrypt(raw_cipher_data)

МОЯ ОШИБКА MSG

  File ".\app.py", line 24, in <module>
    rsa_key = RSA.importKey(f.read(), passphrase="CNt3wiSY3Sjn0fEh2fsq")
  File "C:\Users\xx\AppData\Local\Programs\Python\Python37-32\lib\site-packages\Cryptodome\PublicKey\RSA.py", line 733, in import_key
    (der, marker, enc_flag) = PEM.decode(tostr(extern_key), passphrase)
  File "C:\Users\xx\AppData\Local\Programs\Python\Python37-32\lib\site-packages\Cryptodome\IO\PEM.py", line 163, in decode
    data = unpad(objdec.decrypt(data), objdec.block_size)
  File "C:\Users\xx\AppData\Local\Programs\Python\Python37-32\lib\site-packages\Cryptodome\Util\Padding.py", line 90, in unpad
    raise ValueError("Padding is incorrect.")
ValueError: Padding is incorrect.

1 Ответ

0 голосов
/ 05 ноября 2018

Я думаю, что ваш ключ RSA зашифрован. Согласно документации, вы должны предоставить такую ​​фразу rsa_key = RSA.importKey(open('pem file location', "rb").read(), passphrase="yourpasswordhere")

...