我需要编写一个python代码,将证书安装到我的计算机(windows)或本地用户的受信任的根证书中。我尝试了以下代码。该代码运行无误,但看起来存储不是Windows受信任的根。我还阅读了 wincert 和 win32crypt python模块的文档,似乎没有任何作用。
import OpenSSL.crypto
cert = OpenSSL.crypto.load_certificate(
OpenSSL.crypto.FILETYPE_PEM,
open('certFile.crt').read()
)
store = OpenSSL.crypto.X509Store()
if not store.add_cert(cert):
print('Success')
编辑:我需要做类似here的事情,但要使用python。
编辑2:我也尝试了以下方法(不确定它是否可以完成预期的工作):
import win32crypt
import sys
CERT_STORE_PROV_SYSTEM = 0x0000000A
CERT_STORE_OPEN_EXISTING_FLAG = 0x00004000
CRYPT_STRING_BASE64HEADER = 0x00000000
def main():
store = win32crypt.CertOpenStore(CERT_STORE_PROV_SYSTEM, 0, None, CERT_SYSTEM_STORE_LOCAL_MACHINE|CERT_STORE_OPEN_EXISTING_FLAG, "ROOT")
cert_str = open('D:\\Certificates\\certFile.crt').read()
cert_byte = win32crypt.CryptStringToBinary(cert_str, CRYPT_STRING_BASE64HEADER)[0]
win32crypt.CertAddSerializedElementToStore(store,cert_byte,1,2,0)
if __name__ == "__main__":
main()
print('done')
但出现以下错误:
win32crypt.CertAddSerializedElementToStore(store,cert_byte,1,2,0)
pywintypes.error: (-2146885629, 'CertAddSerializedElementToStore', 'An error occurred while reading or writing to a file.')
答案 0 :(得分:0)
这段代码对我有用。以防万一,将其张贴在这里。
#Flag variables
CERT_STORE_PROV_SYSTEM = 0x0000000A
CERT_STORE_OPEN_EXISTING_FLAG = 0x00004000
CRYPT_STRING_BASE64HEADER = 0x00000000
CERT_SYSTEM_STORE_CURRENT_USER_ACCOUNT = 1<<16
X509_ASN_ENCODING = 0x00000001
CERT_STORE_ADD_REPLACE_EXISTING = 3
CERT_CLOSE_STORE_FORCE_FLAG = 0x00000001
#replace with your certificate file path
crtPath = "D:\\certificates\\cert_file.crt"
with open(crtPath,'r') as f:
cert_str = f.read()
cert_byte = win32crypt.CryptStringToBinary(cert_str, CRYPT_STRING_BASE64HEADER)[0]
store = win32crypt.CertOpenStore(CERT_STORE_PROV_SYSTEM, 0, None, CERT_SYSTEM_STORE_CURRENT_USER_ACCOUNT|CERT_STORE_OPEN_EXISTING_FLAG, "ROOT")
try:
store.CertAddEncodedCertificateToStore(X509_ASN_ENCODING, cert_byte, CERT_STORE_ADD_REPLACE_EXISTING)
finally:
store.CertCloseStore(CERT_CLOSE_STORE_FORCE_FLAG)
仅供参考, pywin32 库提供了win32crypt模块。您可以通过运行此命令来安装它。
pip安装pywin32