读取PEM字符串时出现PyAsn1错误

时间:2014-08-11 12:52:14

标签: python python-3.x rsa python-3.4 pem

我试图在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)

Screen RSA Documentations

1 个答案:

答案 0 :(得分:3)

我不确定我做得对。但至少在加密后没有错误。

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中运行它)。