Код работает на Python 3.6, но не работает в 3.7 - PullRequest
0 голосов
/ 22 января 2019

Я начал изучать python и сокеты в те дни, и я сделал простое клиент-серверное приложение только для того, чтобы провести несколько тестов, и оно отлично работает с Python 3.6, но выдает ошибку в последней версии.

Server.py

import socket, ssl

context = ssl.create_default_context(ssl.Purpose.CLIENT_AUTH)
context.verify_mode = ssl.CERT_REQUIRED
context.load_cert_chain(certfile="SSL/server.crt", keyfile="SSL/server.key")
context.load_verify_locations("SSL/client.crt")

bindsocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
bindsocket.bind(("127.0.0.1", 65405))
bindsocket.listen(10)

while True:
    newsocket, fromaddr = bindsocket.accept()
    print(newsocket)
    connstream = context.wrap_socket(newsocket, server_side=True)
    try:
        print(connstream.getpeercert())
    finally:
        connstream.shutdown(socket.SHUT_RDWR)
        connstream.close()

Client.py

import ssl, socket

context = ssl.create_default_context(ssl.Purpose.SERVER_AUTH)
context.load_cert_chain(certfile="SSL/client.crt", keyfile="SSL/client.key")
context.verify_mode = ssl.CERT_REQUIRED
context.check_hostname = True
context.load_verify_locations("SSL/server.crt")

conn = context.wrap_socket(socket.socket(socket.AF_INET, socket.SOCK_STREAM), server_hostname="127.0.0.1")

try:
    conn.connect(("127.0.0.1", 65405))
    conn.sendall(b"aff")
    print(conn.getpeercert())
except:
    print("não")
finally:
    conn.shutdown(socket.SHUT_RDWR)
    conn.close()

Error

Traceback (most recent call last):
    File "C:/Users/nicol/Desktop/Kyuu/Bot/Kaori/Python/server.py", line 15, in <module>
    connstream = context.wrap_socket(newsocket, server_side=True)
    File "C:\Users\nicol\AppData\Local\Programs\Python\Python37\lib\ssl.py", line 412, in wrap_socket
    session=session
    File "C:\Users\nicol\AppData\Local\Programs\Python\Python37\lib\ssl.py", line 853, in _create
    self.do_handshake()
    File "C:\Users\nicol\AppData\Local\Programs\Python\Python37\lib\ssl.py", line 1117, in do_handshake
    self._sslobj.do_handshake()
ssl.SSLError: [SSL: SSLV3_ALERT_BAD_CERTIFICATE] sslv3 alert bad certificate (_ssl.c:1056)

Редактировать 1

Я пытался использовать ssl.SSLContext (ssl.PROTOCOL_TLS_SERVER) и ssl.SSLContext (ssl.PROTOCOL_TLS_CLIENT), но я получил ту же ошибку.

Редактировать 2

Когда я использую команду "s_client -connect 127.0.0.1:65405 -cert client.pem -key client.pem -CAfile server.crt" в OpenSSL, она отлично работает

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...