【问题标题】:Python WebSocket Client connecting but not sending messagesPython WebSocket客户端连接但不发送消息
【发布时间】:2017-12-19 22:52:14
【问题描述】:

在使用 websocket 客户端向 django 服务器发送测试消息时,我无法让一个可以发送和接收消息的脚本工作。

以下python脚本是我尝试过的:

import websocket
import threading
import json
from time import sleep

# handle message event
def on_message(ws, message):
    print("message recieved: %s" % message)

# handle close event
def on_close(ws):
    print("channel closed")

# execute as main script
if __name__ == "__main__":
    websocket.enableTrace(True)
    # new app object connecting to headstation
    ws = websocket.WebSocketApp("ws://192.168.0.106:8000/?testI123", on_message = on_message, on_close = on_close)
    # run in a new thread - kill if script ends
    ws_listener = threading.Thread(target=ws.run_forever())
    ws_listener.daemon = True
    # start second thread
    ws_listener.start()

    # attempt connection 5 times
    timeout = 5
    while not ws.sock.connected and timeout:
        sleep(1)
        timeout -= 1
    # error on timeout
    if (timeout == 0):
        print("Connection to server timed out") 

    print("test 1")
    # periodically send test message to server
    message_num = 0
    while ws.sock.connected:
        # send node id and message
        message = 'hello %d'%message_num
        ws.send(message)
        sleep(1)
        message_num += 1

此连接成功,由服务器指示,并接收服务器发送的消息,但不发送任何内容。

定期在终端上显示类似这样的内容:

send: b'\x8a\x84\xe2\xe9\xa8\xe2\x8f\xdc\xe2\x84'

如果我只是使用

ws = websocket.WebSocket()
ws.connect(url)
ws.send("hello")

那么这很完美。建议上面显示的我的小python脚本有问题。

【问题讨论】:

    标签: python django websocket python-multithreading channels


    【解决方案1】:

    找到问题了,当然是愚蠢的错误:

     ws_listener = threading.Thread(target=ws.run_forever())
    

    应该是:

     ws_listener = threading.Thread(target=ws.run_forever)
    

    没有括号。

    第一个将 ws.run_forever 的结果传递给目标,第二个将 ws.run_forever 设置为目标,这是预期的结果。

    【讨论】:

      猜你喜欢
      • 2017-09-30
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-07-18
      相关资源
      最近更新 更多