0

我正在通过python创建一个websocket服务器(我对python有点陌生)并且我已经取得了重大进展,但我无法将数据发送到网络浏览器。我可以建立连接并从浏览器接收数据,但无法发回数据。浏览器只是忽略它。我假设如果浏览器收到一个不符合规范的包,它将终止连接,但连接保持活动状态。

这是我用来将数据编码到帧中的方法:

def encode_message(data):
    frame = "\x81"
    size = len(data)
    if size * 8 <= 125:
        frame += chr(size)
    else:
        raise Exception("Uh, oh. Strings larger than 125 bits are not supported")

    return frame + data

我正在使用sock.sendall(framed_data). 可能是什么问题呢?像“yo”这样的消息的数据最终是10000001 00000010 01111001 01101111(添加空格以提高可读性)。为什么浏览器不接受这样的消息?它不遵循规范中概述的准则?我正在尝试支持我认为是版本 13 的最新 websocket 版本。我使用的是 python 版本 2.7.3。

我曾尝试查看 python websocket 库的源代码,但它们似乎都实现了已被证明存在漏洞的已弃用的 websocket 协议版本。

下面是调用上述函数的代码:

def send(data):
    frame = encode_message(data)
    print "Sending all..."
    sock.sendall(frame) #Socket that handles all communications with client
    print "Frame sent :)"
    return

我还下载了wireshark来嗅探服务器和套接字之间发送的包。我的服务器发送的包与浏览器接受的服务器发送的包相同。我根本看不出有什么不同。(我直接查看了十六进制源)

4

2 回答 2

1

您传输的消息的第二个字节(以及代码中的长度检查)看起来是错误的。消息的长度以字节为单位,而不是位。

来自RFC6455 §5.2(我的重点)

有效载荷长度:7 位、7+16 位或 7+64 位

“有效负载数据”的长度,以字节为单位:如果为 0-125,则为有效负载长度。

浏览器没有收到任何内容的原因是您的消息声称有一个 16 字节的正文。浏览器将读取您发送的另外 2 个字节,然后阻止等待它期望但您不发送的另外 14 个字节。

如果您将第二个字节更改为消息中的字节数 - 0x2 或 00000010 二进制 - 那么事情应该可以工作。

于 2013-05-13T21:33:46.833 回答
0

我终于弄清楚了问题所在!我花了好几个小时调试和弄乱我的代码。在仔细检查了服务器和客户端之间来回发送的包之后,我终于意识到我的服务器的连接升级响应存在问题。每当它计算一个哈希值时,它也会在\n它的末尾添加一个。这导致 a\n\r\n在其中一行的末尾。客户端将其解释为该传输的结束,随后的所有内容都使用 WebSocket 协议进行解析。我在标题之后还有另一行,所以它完全搞砸了我与客户的沟通。我仍然可以从客户端读取,但如果我尝试写入客户端,数据就会变得混乱。

于 2013-05-16T15:45:54.067 回答