【问题标题】:Always an Error on the First Message第一条消息总是出错
【发布时间】:2011-03-26 05:41:50
【问题描述】:

目前我正在设置一个基本的 WebSockets 脚本。我可以让客户端连接到服务器,但是每当服务器向客户端发送第一条消息时,客户端就会注册并出错,据我所知,readyState 是打开的,并且应该允许消息通过。该消息具有正确的 /x00 和 /xff 开头。我不知道出了什么问题。

编辑:以下是似乎导致错误的代码。 data.js 只是保存了 Python 服务器用来设置服务器的内容,所以当我测试它并且端口还没有超时时,我只需要更改一个文件。

客户端:

<html>
<head>
<script type="text/javascript" src="data.js">
</script>
<script type="text/javascript">
var ws, error
init = function() {
  ws = new WebSocket("ws://127.0.0.1:"+port+"/websockets/main.py")
  ws.onopen = function() {
    console.log("Connected")
    log("Connected")
  }
  ws.onmessage = function(e) {
    console.log("Received data")
    log(e.data)
  }
  ws.onerror = function(e) {
    console.log(e)
    ws.send("Error occurred. Resend")
  }
}
log = function(msg) {
  document.getElementById("log").appendChild(document.createElement("br"))
  document.getElementById("log").innerHTML = document.getElementById("log").innerHTML+msg
}
</script>
</head>
<body onload="init()">
<div id="log">
</div>
</body>
</html>

服务器端:

import threading, hashlib, socket, time, re, struct

class WebSocketThread(threading.Thread):
  def __init__(self, channel, details, websocket):
    self.channel = channel
    self.details = details
    self.websocket = websocket
    threading.Thread.__init__(self)

  def run(self):
    print("> Received connection ", self.details[0])
    self.handshake(self.channel)
    while True:
        self.interact(self.channel)

  def finduser(self, client):
    for user in self.websocket.users:
      if user.socket == client:
        return user
        return 0

  def send_data(self, user, data):
    user.socket.send(self.wrap(data))
    print ("> Sent data", data, "to", user)

  def recv_data(self, client, count):
    data = client.recv(count)
    return data

  def handshake(self, client):
    shake = self.recv_data(client, 256)
    our_handshake = self.create_response(shake)
    client.send(our_handshake)
    print ("> Accepted client ", self.finduser(client))
    self.send_data(self.finduser(client), "Test")

  def interact(self, client):
    users = self.websocket.users
    this_user = self.finduser(client)
    data = self.unwrap(self.recv_data(client, 256))
    print ("> Received data ", data, "from", this_user)

  def create_response(self, data):
    key3 = ""
    lines = data.splitlines()
    resource = re.compile("GET (.*) HTTP").findall(data)
    resource = resource[0]
    for line in lines:
      parts = line.partition(": ")
      if parts[0] == "Host":
        host = parts[2]
      elif parts[0] == "Origin":
        origin = parts[2]
      elif parts[0] == "Sec-WebSocket-Key1":
        key1 = parts[2]
      elif parts[0] == "Sec-WebSocket-Key2":
        key2 = parts[2]
      key3 = line
    spaces1 = key1.count(" ")
    spaces2 = key2.count(" ")
    num1 = int("".join([c for c in key1 if c.isdigit()]))/spaces1
    num2 = int("".join([c for c in key2 if c.isdigit()]))/spaces2
    token = hashlib.md5(struct.pack(">II8s", num1, num2, key3)).digest()
    return "HTTP/1.1 101 WebSocket Protocol Handshake\r\nUpgrade: WebSocket\r\nConnection: Upgrade\r\nSec-WebSocket-Origin: %s\r\nSec-WebSocket-Location: ws://%s%s\r\nSec-WebSocket-Protocol: sample\r\n\r\n%s\r\n"% (origin, host, resource, token)

  def unwrap(self, data):
    return data[1:-1]

  def wrap(self, data):
    return ("\x00"+data+"\xff")

【问题讨论】:

  • 错误是什么?你能把代码贴出来吗
  • 我无法读取错误。它只是一个错误对象,没有消息或任何东西。你想要代码的哪一部分?客户端还是服务器端?
  • 两者都可能是必要的。
  • 您使用的是哪个客户端/浏览器版本?哪个 WebSockets 服务器?您是否正在修改服务器(这就是您知道消息正确开始和结束的原因)?
  • 我使用的是最新版本的 Google-Chrome。我正在使用一个在发送之前添加每条消息的开头和结尾的函数,因此我知道它已正确发送。我将使用代码编辑原始消息。

标签: javascript python html websocket


【解决方案1】:

尝试删除令牌后的最后一个 \r\n:

return "HTTP/1.1 101 WebSocket Protocol Handshake\r\nUpgrade: WebSocket\r\nConnection: Upgrade\r\nSec-WebSocket-Origin: %s\r\nSec-WebSocket-Location: ws://%s%s\r\nSec-WebSocket-Protocol: sample\r\n\r\n%s"% (origin, host, resource, token)

我相信它会解决你的问题:)

【讨论】:

  • 非常感谢。 ^^ 我发誓我见过的所有例子都有它。我正要放弃想办法。我想这是小事。
  • 也遇到了这个问题,搜索了将近一周:D
猜你喜欢
  • 2012-07-23
  • 2012-06-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-09-27
  • 2019-01-08
  • 1970-01-01
  • 2012-03-09
相关资源
最近更新 更多