我正在试用 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!
这是什么意思?我是不是做错了什么?
最佳答案
websocket.Upgrade函数 hijacks the the underlying network connection from the http.ResponseWriter .
ResponseWriter.Write方法 logs this message when write is called after the connection is hijacked from the writer .
看起来应用程序使用的路由器或中间件正在 websocket 处理程序返回后写入连接。
关于go - 为什么我会收到错误消息 "http: response.Write on hijacked connection"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32657603/