PyOpenSSL将证书对象转换为.pem文件

时间:2012-03-20 23:45:43

标签: python sockets pem pyopenssl

我想通过套接字将证书从“证书颁发机构”发送到节点。 我有一个使用此示例创建的证书 https://skippylovesmalorie.wordpress.com/2010/02/12/how-to-generate-a-self-signed-certificate-using-pyopenssl/ 我如何将其转换为.pem文件,以便我可以通过套接字将其作为字符串发送,然后在另一端将其转换回.pem并使用get_certificate从中提取此证书。 Python: reading a pkcs12 certificate with pyOpenSSL.crypto 它可能是一种hacky方式,但我想为自己简化它。 (或不)

我正在复活这个人的问题,而这个问题没有得到回答 How to convert PyOpenSSL object to PEM-encoded string?

1 个答案:

答案 0 :(得分:9)

这是用于生成证书签名请求,但概念应该相同

from OpenSSL import crypto

req = crypto.X509Req()
pkey = crypto.PKey()
pkey.generate_key(crypto.TYPE_RSA, 2048)
req.set_pubkey(pkey)
req.sign(pkey, 'sha1')
certreq = crypto.dump_certificate_request(crypto.FILETYPE_PEM, req)
certreq = certreq.replace('-----BEGIN CERTIFICATE REQUEST-----\n', '').replace('-----END CERTIFICATE REQUEST-----\n', '')
private_key = crypto.dump_privatekey(crypto.FILETYPE_PEM, pkey)

您可以使用的证书:

crypto.dump_certificate(type, cert)