Go Flush()不起作用

时间:2014-10-13 07:53:14

标签: go flush martini

拜托,检查一下这个要点并告诉我,这有什么不对?
为什么我看不到我的消息?
要点:https://gist.github.com/cnaize/895f61b762a9f5ee074c

如果简单,我有两个功能:

func send(param martini.Params, r render.Render) {
    Ct.Msgs <- param["msg"]

    fmt.Printf("Sent: %v", param["msg"])

    r.JSON(http.StatusOK, Response{"status": "ok"})
}

watch功能:

func watch(rw http.ResponseWriter, r render.Render) {
    var msg string
    ok := true
    for ok {
        select {
        case msg, ok = <-Ct.Msgs:
            rw.Write([]byte(msg))
            fmt.Printf("Wrote: %v", msg)
            f, ok := rw.(http.Flusher)
            if ok {
                f.Flush()
                fmt.Println("Flushed")
            } else {
                r.JSON(http.StatusOK, Response{"status": "error", "descr": "CANT_FLUSH"})
                return
            }
        }
    }

    r.JSON(http.StatusOK, Response{"status": "ok", "descr": "finished"})
}

为什么它不起作用?

编辑:

我更新了我的要点。 现在在哪里:

if i, err := rw.Write([]byte(msg)); err != nil {
    r.JSON(http.StatusOK, Response{"status": "error", "descr": err.Error()})
    return
} else {
    fmt.Printf("i: %v", i)
}

我有日志:

 Sent: hello
 i: 5
 Wrote: hello
 Flushed

但我什么也没看到。

有什么想法吗?

1 个答案:

答案 0 :(得分:3)

同花顺正在运作。问题是Chrome的纯文本渲染器在显示任何内容之前等待完整的响应正文。强制将内容类型设置为html以查看增量响应:

func watch(rw http.ResponseWriter, r render.Render) {
    rw.Header().Set("Content-Type", "text/html")
    // same code as before
}