ValueError:不是有效的PEM前边界

时间:2015-12-17 12:53:21

标签: python python-3.x pycrypto pem

这段代码

key=RSA.importKey(open("receiver.pem","rb").read())

返回此错误

ValueError: Not a valid PEM pre boundary

key=RSA.importKey(open("receiver.pem","r").read())

返回

ValueError: Not a valid PEM post boundary

当我们使用Pycrypto和Python 2.7时,代码工作正常,现在我已转移到Pycryptodome和Python 3.4.3(使用2to3)。但现在这段代码不起作用。我甚至无法尝试任何事情,因为我甚至无法理解它的含义。

要生成.PEM文件,请使用此代码。

random_generator = Random.new().read
rsakey = RSA.generate(1024, random_generator)
f=open(email+'.pem','wb')
f.write(rsakey.exportKey("PEM"))
f.write(rsakey.publickey().exportKey("PEM"))
f.close()

这就是.PEM文件的内容。

-----BEGIN RSA PRIVATE KEY-----
MIICWwIBAAKBgQCIQhU/+nPVFgw+T0Tf7NEpHYB12I/qywo5xBdp5kaLxEHD9zOx
2FTOX2OMPiL7fv/PW/AXuSrvD3pZAFzGmkigWdQP6TES5ZM65LUzeUUy8noHkZ00
D4mz+4a4YtBGaFyNL2CCxOAczi9rx5UB6qbY6+5kkBNd7k75XDp28g2bjwIDAQAB
AoGAaFRQ+P/HmSyci0ker2YgcJ7KMXF0II7+cWSXmNpcwb+vq2CoEFBX/vxCuKsL
Fg4TyK3YlBGPsiPjxink35xaZm7eI5sqbmD8Bnw4JZsQ1FN/Si6pbNLZkmOxyZgl
CoQvuvLavKH5GSWQ5wqvLD6OHBGd7w0YyGVOQHNQvOKhLgECQQC6EgYqOOz8ddQ2
qaLHxJl1LwpwvA4nWUWqeP69yl4QrhOmfTyLxLmw8HJFuz8XYiAxKq9fxnrU0j8H
W+QKwxRBAkEAu3eVGHZF5AA+K/Co+y2MTh1uzaSqbPZY/D4+zs1eLxoVM/e0MLYI
SqPciDTHl3HjZqivpJ5SbU3DcfvGSlV7zwJAJUxRogsRLjYsWNy+PY8iN8Q7Mofv
ymFxvo9MeRzkqDFMzRXTmizQEDDSpzm2luhbjZ+B0hAGNT0D12TLHIEoQQI/N6dI
m/qAxS9NRb4sbGUZQhd6zZIVBkQcJsZT3xEY5OLZaJQg6lUgIQiEb+s7Vbp5yABM
JJLb5ZcwbqZQN8EpAkEAt716AEn2qyxONCfLan1tuZVF+3V0KVphdhu6gdXpyHBv
9hLm2Ezb5VXMoU+IoeYGQ3SaSr6Gb1ein/sXGyaZuQ==
-----END RSA PRIVATE KEY----------BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCIQhU/+nPVFgw+T0Tf7NEpHYB1
2I/qywo5xBdp5kaLxEHD9zOx2FTOX2OMPiL7fv/PW/AXuSrvD3pZAFzGmkigWdQP
6TES5ZM65LUzeUUy8noHkZ00D4mz+4a4YtBGaFyNL2CCxOAczi9rx5UB6qbY6+5k
kBNd7k75XDp28g2bjwIDAQAB
-----END PUBLIC KEY-----

2 个答案:

答案 0 :(得分:2)

由于this function

,您收到了该错误
def decode(pem_data, passphrase=None):
    ...

    # Verify Pre-Encapsulation Boundary
    r = re.compile("\s*-----BEGIN (.*)-----\n")
    m = r.match(pem_data)
    if not m:
        raise ValueError("Not a valid PEM pre boundary")
    marker = m.group(1)

    # Verify Post-Encapsulation Boundary
    r = re.compile("-----END (.*)-----\s*$")
    m = r.search(pem_data)
    if not m or m.group(1) != marker:
        raise ValueError("Not a valid PEM post boundary")

不幸的是,在非多线正则表达式中,$表示"字符串结尾"。这意味着PyCryptoDome期望字符串末尾的END边界,并且没有办法解决这个问题。

您有三种选择:

  • 拆分两个键并分别导入;
  • 修复PyCryptoDome;
  • 切换回PyCrypto。

答案 1 :(得分:0)

Peter Wood之前所述,问题是行尾格式。

我正在CentOS中使用python 2.7开发一个项目,并且我从一个网站获得了一个公钥,这给了我上面的错误。

问题是它带有\ r \ n行尾,这使得python-jose库jwt.decode调用pyCripto库失败。

我的解决方法是在以这种方式返回响应之前删除'\ r'字符:

<pre>
response = get(url).content
return response.replace('\r', '')

这终于使事情正常了。希望有帮助!