python - 如何使用python下载x509证书

标签 python python-3.x ssl ssl-certificate x509

我需要将服务器证书下载为 DER 文件。我正在使用 python 。我可以使用此脚本连接到服务器,但我需要将证书本地下载到我的硬盘中,以便我可以在下一阶段解析它。

import socket, ssl
import OpenSSL

hostname='www.google.com'
port=443

context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2)

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
ssl_sock = context.wrap_socket(s, server_hostname=hostname)
ssl_sock.connect((hostname, port))
ssl_sock.close()
print("ssl connection Done")

cert = ssl.get_server_certificate((hostname, port))

# OpenSSL
x509 = OpenSSL.crypto.load_certificate(OpenSSL.crypto.FILETYPE_PEM, cert)

最佳答案

没有必要显式连接到服务器,因为 get_server_certificate 已经为您做了这件事。您唯一需要做的就是将 get_server_certificate 返回的 PEM 转换为您想要的 DER:

import ssl
hostname='www.google.com'
port=443

f = open('cert.der','wb')
cert = ssl.get_server_certificate((hostname, port))
f.write(ssl.PEM_cert_to_DER_cert(cert))

关于python - 如何使用python下载x509证书,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41171891/

相关文章:

python - Django:使用 SQL 手动更改模型字段有哪些缺点?

python - 将值放在矩阵中的随机位置

具有多种模式的 Python re.findall

java - MySQL JDBC over SSL 问题

python-3.x - 如何通过 SSL 使用 XMLRPC Client ServerProxy

python - Qt Pyside 在小部件中显示结果

python - 获取所有希腊语 unicode 字符的列表

python - 如何在递归表中插入行和列

django - UnicodeEncodeError [Python3/Gunicorn/Nginx/Django]

.htaccess - 如果页面 url 包含特定单词,如何禁用 SSL