Websockets закрытие соединения сразу после рукопожатия - PullRequest
0 голосов
/ 21 января 2020

Я пытаюсь открыть безопасный WebSocket, и когда соединение открыто, я хочу отправить JSON запрос и дождаться ответа. Нужно это для автоматизации BackEnd тестирования. Но я пробую этот код и получаю

websockets.exceptions.ConnectionClosedError: code = 3000 (зарегистрирован), без причины

Мой коллега говорит мне, что кажется, что Я открываю соединение, делаю рукопожатие, а затем сразу же закрываю его! Я хотел бы остаться открытым, если это возможно! Это код, который возвращает мне «ошибку» 3000

import asyncio
import websockets
import ssl
import logging
import time

logger = logging.getLogger('websockets')
logger.setLevel(logging.INFO)
logger.addHandler(logging.StreamHandler())


serv = 'wss://"adress":"PORT"'
print("1")
ssl_context = ssl.SSLContext(protocol=ssl.PROTOCOL_TLSv1_2)
print("2")
json_s = {"msgType":1,"tag":12345,"username":"abc","password":"defghijk"}
print("3")
async def get_msg(uri):
    async with websockets.connect(uri) as ws:
        await ws.send(json_s)
        print("4")
        time.sleep(3)
        print('data sent')
        time.sleep(3)
        resp = await ws.recv()
        print("5")
        time.sleep(3)


    return resp
print("6")

loop = asyncio.get_event_loop().run_until_complete(get_msg(serv))
print("7")
loop.create_task(get_msg(serv))
print("8")
loop.run_forever()
print("9")

Я получаю

    1
    2
    3
    6
    4
    data sent
    Traceback (most recent call last):
      File "C:/Users/Korisnik/PycharmProjects/TACHYON/Test/Websockets doc test.py", line 34, in <module>
        loop = asyncio.get_event_loop().run_until_complete(get_msg(serv))
      File "C:\Users\Korisnik\AppData\Local\Programs\Python\Python38-32\lib\asyncio\base_events.py", line 608, in run_until_complete
        return future.result()
      File "C:/Users/Korisnik/PycharmProjects/TACHYON/Test/Websockets doc test.py", line 26, in get_msg
        resp = await ws.recv()
      File "C:\Users\Korisnik\PycharmProjects\TACHYON1\venv\lib\site-packages\websockets\protocol.py", line 509, in recv
        await self.ensure_open()
      File "C:\Users\Korisnik\PycharmProjects\TACHYON1\venv\lib\site-packages\websockets\protocol.py", line 812, in ensure_open
        raise self.connection_closed_exc()
    **websockets.exceptions.ConnectionClosedError: code = 3000 (registered), no reason**

Process finished with exit code 1

И я застрял здесь ...

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