拜托,检查一下这个要点并告诉我,这有什么不对?
为什么我看不到我的消息?
要点: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
但我什么也没看到。
有什么想法吗?
答案 0 :(得分:3)
同花顺正在运作。问题是Chrome的纯文本渲染器在显示任何内容之前等待完整的响应正文。强制将内容类型设置为html以查看增量响应:
func watch(rw http.ResponseWriter, r render.Render) {
rw.Header().Set("Content-Type", "text/html")
// same code as before
}