【发布时间】:2017-05-03 03:04:30
【问题描述】:
我有以下脚本。它连接到 TLS 服务器并提取 X509 证书公钥:
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)
pk = x509.get_pubkey()
print(pk)
问题是返回的公钥。我需要它的十六进制格式。如何解决这个问题?
这是我得到的输出:
<OpenSSL.crypto.PKey object at 0x0000019EBFDF73C8>
【问题讨论】:
-
目前您只是获取公钥的句柄。你看过
OpenSSL.crypto.dump_publickey(type, pkey)吗?
标签: python ssl cryptography x509