私は以下のスクリプトを持っています。 TLSサーバーに接続し、X509証明書の公開鍵を抽出します。Pythonのx509証明書からRSA公開鍵を取り出す方法
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)
問題は返された公開鍵です。私は16進形式でそれを必要とします。この問題を解決するには?
これは私が取得しています出力されます:
<OpenSSL.crypto.PKey object at 0x0000019EBFDF73C8>
[証明書から公開鍵を抽出してデータを暗号化する]の可能な複製(http://stackoverflow.com/questions/5789193/extracting-public-key-from-certificate-and-encrypting-data) –
現在あなたは公開鍵のハンドルを取得するだけです。あなたは 'OpenSSL.crypto.dump_publickey(type、pkey)'を見ましたか? –