读取PEM字符串时的PyAsn1错误

4 投票
1 回答
4960 浏览
提问于 2025-04-18 16:49

我正在尝试在Python中读取一个PEM编码的公钥。我试过了很多不同的密钥和解决方案。我还尝试了将其进行base64解码,或者用其他格式等等……

我真的不知道该怎么办了(因为这个问题我已经困扰了一整天了)。

我遇到的错误是:

Traceback (most recent call last):
  File "I:/path/Main.py", line 6, in <module>
    -----END RSA PUBLIC KEY-----""", format='PEM')
  File "C:\Python34\lib\site-packages\rsa-3.1.4-py3.4.egg\rsa\key.py", line 65, in load_pkcs1
  File "C:\Python34\lib\site-packages\rsa-3.1.4-py3.4.egg\rsa\key.py", line 192, in _load_pkcs1_pem
  File "C:\Python34\lib\site-packages\rsa-3.1.4-py3.4.egg\rsa\key.py", line 160, in _load_pkcs1_der
  File "C:\Python34\lib\site-packages\pyasn1-0.1.7-py3.4.egg\pyasn1\codec\ber\decoder.py", line 792, in __call__
  File "C:\Python34\lib\site-packages\pyasn1-0.1.7-py3.4.egg\pyasn1\codec\ber\decoder.py", line 321, in valueDecoder
  File "C:\Python34\lib\site-packages\pyasn1-0.1.7-py3.4.egg\pyasn1\codec\ber\decoder.py", line 798, in __call__
pyasn1.error.PyAsn1Error: TagSet(Tag(tagClass=0, tagFormat=32, tagId=16)) not in asn1Spec: {TagSet(Tag(tagClass=0, tagFormat=0, tagId=2)): Integer()}/{}

我的代码是:

pubkey = rsa.PublicKey.load_pkcs1(b"""-----BEGIN RSA PUBLIC KEY-----
MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBANkHLKYS2dByWQ3gKjQDvQbuWb/2Y9z4
eYuLEfgXdiP5qc5cG/5c+c/GgIl6yQY7AYeZVXiBXLaGzxiLZ5Y4fi0CAwEAAQ==
-----END RSA PUBLIC KEY-----""", format='PEM')
crypto = rsa.encrypt("Secret", pubkey)

截图 RSA文档

1 个回答

4

我不太确定自己做得对不对。不过至少在加密的时候没有出错。

import rsa
pubkey = rsa.PublicKey.load_pkcs1_openssl_pem(b"""-----BEGIN PUBLIC KEY-----
MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBANkHLKYS2dByWQ3gKjQDvQbuWb/2Y9z4
eYuLEfgXdiP5qc5cG/5c+c/GgIl6yQY7AYeZVXiBXLaGzxiLZ5Y4fi0CAwEAAQ==
-----END PUBLIC KEY-----""")
crypto = rsa.encrypt(b"Secret", pubkey)

注意:我把 BEGIN RSA PUBLIC KEY 改成了 BEGIN PUBLIC KEY。(END RSA PUBLIC KEY 也是一样的处理)。我使用了 load_pkcs1_openssl_pem

更新

传入一个 bytes 对象,而不是 str(特别是在你使用 Python 3.x 的时候)。

撰写回答