【问题标题】:Python Socket Client SSL ConnectionPython 套接字客户端 SSL 连接
【发布时间】:2021-12-22 19:15:32
【问题描述】:

我已经实现了以下连接到远程服务器:

s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.settimeout(10)
context = SSLContext(ssl.PROTOCOL_TLSv1_2)
context.verify_mode = ssl.CERT_NONE
sslSocket = context.wrap_socket(s, server_hostname=hostname)
sslSocket.connect((hostname, port))

我收到一个错误:

[SSL: WRONG_SSL_VERSION] wrong ssl version (_ssl.c:2820)

当我通过命令行通过 openssl 连接时,这是我从服务器得到的响应:

New, TLSv1/SSLv3, Cipher is ECDHE-RSA-AES128-GCM-SHA256
Server public key is 2048 bit
Secure Renegotiation IS supported
Compression: NONE
Expansion: NONE
No ALPN negotiated
SSL-Session:
    Protocol  : TLSv1.2
    Cipher    : ECDHE-RSA-AES128-GCM-SHA256

我在调用 SSL 版本时遗漏了什么?

【问题讨论】:

    标签: python sockets ssl tls1.2


    【解决方案1】:

    您必须在线更改协议版本: 'ssl.PROTOCOL_TLSv1_2' 到另一个如:ssl.PROTOCOL_SSLV3 我不确定语法。在文档中搜索它。 这: PROTOCOL_SSLv23

    【讨论】:

    • 我收到一个错误:模块 'ssl' 没有属性 'PROTOCOL_SSLv3'。所以现在我已经安装了 pyOpenSSL 并使用它而不是具有此协议的 ssl。在执行 sslSocket.send(post_data.encode('utf-8')) 之后,我现在收到超时错误。这不会返回:buf = sslSocket.recv(4096)
    • 使用 socket.recv 的一个技巧是检查接收方接收了多少字节,并查找一些字符,例如 \0 或 \r\n 以检查您的消息是否完整。它超时的原因是等待一些永远不会被发送到recv端的数据。祝你好运
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2017-12-10
    • 2015-02-08
    • 2012-12-15
    • 2014-01-26
    • 1970-01-01
    • 2021-04-22
    • 2013-04-15
    相关资源
    最近更新 更多