Golang http:多个response.WriteHeader调用

时间:2014-11-04 08:30:25

标签: go websocket

这些天我正在使用Beego框架通过websoket发送消息。 但遇到错误的消息http:多个response.WriteHeader调用 问题出在哪儿? 任何提示都会很棒!

func (this *WsController) Get() {
    fmt.Println("connected")
    handler(this.Ctx.ResponseWriter, this.Ctx.Request, this);
    conn, err := upgrader.Upgrade(this.Ctx.ResponseWriter, this.Ctx.Request, nil)
    if _, ok := err.(websocket.HandshakeError); ok {
        http.Error(this.Ctx.ResponseWriter, "Not a websocket handshake", 400)
        return
    } else if err != nil {
        return
    }
    fmt.Println("connected")
    connection := consumer.New(beego.AppConfig.String("LoggregatorAddress"), &tls.Config{InsecureSkipVerify: true}, nil)

    fmt.Println("===== Tailing messages")
    msgChan, err := connection.Tail(this.Ctx.Input.Param(":appGuid"), this.Ctx.Input.Param(":token"))

    if err != nil {
        fmt.Printf("===== Error tailing: %v\n", err)
    } else {
        for msg := range msgChan {
            // if  closeRealTimeLogFlag{
            //  consumer.Close()
            //  break
            // }
            if err = conn.WriteMessage(websocket.TextMessage, msg.Message); err != nil {
                fmt.Println(err)
            }
            fmt.Printf("%v \n", msg)
        }
    }

}

1 个答案:

答案 0 :(得分:-4)

因为你写的不仅仅是statusCode