Python3 Cryptodome - 如何解密pem?

标签 python python-3.x encryption rsa pycryptodome

我正在尝试使用 cryptodome 在 python 中解密我的私钥。 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)

我的错误信息

  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.

最佳答案

我认为您的 RSA key 已加密。根据文档,您应该提供这样的密码 rsa_key = RSA.importKey(open('pem 文件位置', "rb").read(), passphrase="yourpasswordhere")

关于Python3 Cryptodome - 如何解密pem?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53155468/

相关文章:

python - 服务器未在 hello world 应用程序中启动

python - 如何解析差距?

encryption - Blackberry 内容保护和持久存储

Python 用条件将两个列表相交

python - 从包导入时模块抛出名称错误

python - 在 PyQt 中使用一个信号处理程序连接多个小部件信号

security - 保护没有关联域名的公共(public)服务器 IP

java - 生成给定长度的 AES key ,其中包含 a-Z0-9

python - ffmpeg-python跟踪转码过程

python - Python中变量名后的下划线