ssl.get_server_certificate 用于具有 SNI(服务器名称指示)的站点
问题描述
我正在尝试获取 badssl.com 子域的服务器证书(例如 https://expired.badssl.com).
I am trying to get the server certificate of badssl.com subdomains (ex. https://expired.badssl.com).
import ssl
ssl.get_server_certificate(('expired.badssl.com', 443))
但是在检查上面生成的证书时,我看到证书有
But when examining the above generated certificate I see that the certificate has
身份:badssl-fallback-unknown-subdomain-or-no-sni
Identity: badssl-fallback-unknown-subdomain-or-no-sni
这意味着 SNI 失败.如何获取 badssl.com 不同子域的服务器证书?(我使用的是python 2.7.12)
which means SNI is failing. How can I get the server certificate of different subdomains of badssl.com? (I am using python 2.7.12)
解决方案
找到答案了.
import ssl
hostname = "expired.badssl.com"
port = 443
conn = ssl.create_connection((hostname, port))
context = ssl.SSLContext(ssl.PROTOCOL_SSLv23)
sock = context.wrap_socket(conn, server_hostname=hostname)
certificate = ssl.DER_cert_to_PEM_cert(sock.getpeercert(True))
相关文章