Четене на X509 сертификат в Python

Имам следния код в C#, който върши работата, за която се нуждая:

//Try create an X509 cert object
X509Certificate x509Cert = new X509Certificate("C:/Users/mryan/Documents/Code/SampleApps/bundle.p12", "passphrase");

//Serialize Cert and POST to server
string devString = Newtonsoft.Json.JsonConvert.SerializeObject(x509Cert);

result = wc.UploadString(apiRoot + "/Accounts/" + accId + "/certs", "POST", devString)

Така че тук devString ще бъде равно на:

"{\"RawData\":\"MIICiTCCAfKgAwI...OhpEV23wsm06G2s5OJk=\"}"

Доколкото мога да разбера, RawData е свойство в x509Cert, което се равнява на масив от байтове.

Има ли някакъв очевиден модул в python, който може да постигне същия резултат? Гледах този отговор, но не мога да кажа дали отразява това, което искам да постигна.

Желан псевдокод на Python:

#Create X509 Cert object
x509cert = module.readX509Certificate("C:/Users/mryan/Documents/Code/SampleApps/bundle.p12", "passphrase")
cert_data = {"RawData": x509Cert}
result = requests.post(apiRoot + "/Accounts/" + accId + "/certs", data=cert_data)

Всякакви идеи как да се справя с това ще са страхотни!


person TomSelleck    schedule 18.06.2014    source източник


Отговори (1)


Ако разбирам въпроса ви, трябва да заредите сертификат PKCS#12 и след това да качите публичния ключ (сертификат) на сървър. Това може да стане с крипто модула на pyopenssl.

import json
import requests
from OpenSSL import crypto

P12_CERT_FILE = 'C:/Users/mryan/Documents/Code/SampleApps/bundle.p12'
p12_cert = crypto.load_pkcs12(open(P12_CERT_FILE).read(), 'passphrase')
pem_cert = crypto.dump_certificate(crypto.FILETYPE_PEM, p12_cert.get_certificate())

# remove PEM header, footer, and new lines to produce raw cert data
raw_data = ''.join(pem_cert.split('\n')[1:-2])
cert_data = json.dumps({'RawData': raw_data})
result = requests.post(apiRoot + "/Accounts/" + accId + "/certs", data=cert_data)
person mhawke    schedule 19.06.2014