我想创建python脚本,这将采用PKCS#12包并打印x509证书中包含的一些信息并用于此purpouse PyOpenSSL模块。到目前为止,我想从证书公钥中获取。但是PKey对象没有合适的方法。我可以从哪里搬出去?任何想法如何获得公钥?
pfx=open('./1.p12','rb').read()
PKCS=crypto.load_pkcs12(pfx)
cert=PKCS.get_certificate()
PKey=cert.get_pubkey()
print PKey
<OpenSSL.crypto.PKey object at 0x012432D8>
感谢。
答案 0 :(得分:4)
首先,你可以像这样加载证书
from OpenSSL import crypto
#cert is the encrypted certificate int this format -----BEGIN -----END
crtObj = crypto.load_certificate(crypto.FILETYPE_PEM, cert)
pubKeyObject = crtObj.get_pubkey()
pubKeyString = crypto.dump_publickey(crypto.FILETYPE_PEM,pubKeyObject)
print pubKeyString
你会看到像
这样的东西-----BEGIN PUBLIC KEY-----
....
....
-----END PUBLIC KEY-----
答案 1 :(得分:0)
我假设您想从文件中读取公共密钥。
首先安装pyopenssl
点安装pyopenssl
from OpenSSL import crypto
import os
file_path = os.path.join(os.getcwd(),'/certificates/test.crt')
f = open(file_path, "r")
cert = f.read()
pub_key_obj = crypto.load_certificate(crypto.FILETYPE_PEM, cert).get_pubkey()
pub_key = crypto.dump_publickey(crypto.FILETYPE_PEM,pub_key_obj)
print(pub_key)
您将获得以下输出:
----- BEGIN公钥-----
....
----- END公钥-----
答案 2 :(得分:-2)
这会有用吗?
print PKey
<OpenSSL.crypto.PKey object at 0x012432D8>
from OpenSSL import crypto
crypto.dump_privatekey(PKey)
答案 3 :(得分:-2)
改为使用:
c.dump_privatekey(c.FILETYPE_TEXT,pubkey)