我正在尝试使用gorilla websocket库来了解websockets如何与Go一起使用。但是当我点击浏览器上的刷新按钮时,我不断收到此错误消息。
当我重新加载我用来测试websocket的网页时,我在Go控制台上收到这些错误消息:
2015/09/18 19:04:41 websocket: close 1001
2015/09/18 19:04:41 http: response.Write on hijacked connection
第一个是"离开"的状态代码。我假设这是因为当我点击刷新时它会远离websocket连接,这对我来说很有意义。
然后我收到一条我不明白的错误信息。被劫持的人。为什么我明白这是什么意思?
我正在Windows机器上的localhost:8080上运行我的代码。
我正在使用的代码:
func wsHandler(w http.ResponseWriter, r *http.Request, _ httprouter.Params) error {
conn, err := websocket.Upgrade(w, r, nil, 1024, 1024)
if err != nil {
return err
}
defer conn.Close()
for {
_, msg, err := conn.ReadMessage()
if err != nil {
return err
}
log.Println(string(msg))
}
return nil
}
客户方:
var conn = new WebSocket("ws://localhost:8080/api/messages/websocket");
conn.onclose = function (e) {
console.log("onclose fired");
};
conn.onopen = function (e) {
console.log("onopen fired");
};
conn.onmessage = function (e) {
console.log(e.data);
};
setTimeout(function () {
conn.send("foo!");
}, 1500);
第一次加载页面时,只有foo!
输出到控制台。总而言之,在加载页面一次,然后重新加载两次后,我得到一个这样的输出:
2015/09/18 19:04:39 foo!
2015/09/18 19:04:41 websocket: close 1001
2015/09/18 19:04:41 http: response.Write on hijacked connection
2015/09/18 19:04:43 foo!
2015/09/18 19:04:44 websocket: close 1001
2015/09/18 19:04:44 http: response.Write on hijacked connection
2015/09/18 19:04:46 foo!
这是什么意思?我做错了什么?
答案 0 :(得分:3)