为什么我会在被劫持的连接上收到错误消息" http:response.Write"?

时间:2015-09-18 17:13:39

标签: go websocket

我正在尝试使用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!

这是什么意思?我做错了什么?

1 个答案:

答案 0 :(得分:3)