3 回答
TA贡献1866条经验 获得超5个赞
您需要在访问底层字节之前刷新或关闭您的 gzip 编写器,例如
func gzipFast(a *[]byte) []byte {
var b bytes.Buffer
gz := gzip.NewWriter(&b)
if _, err := gz.Write(*a); err != nil {
gz.Close()
panic(err)
}
gz.Close()
return b.Bytes()
}
否则,gzip writer 中的缓冲区,但尚未写入最终流的内容不会被收集起来。
TA贡献1825条经验 获得超4个赞
我认为问题在于使用fmt.Fprint(w, gzipFast(&b)).
如果您查看 gzipFast 的定义,它会返回一个[]byte. 您正在将此切片放入 print 函数中,该函数将所有内容“打印”到w.
如果你看一下 io.Writer 的定义:
type Writer interface {
Write(p []byte) (n int, err error) }
您会看到作者可以将其[]byte作为输入进行处理。
而不是fmt.Fprint(w, gzipFast(&b))你应该使用w.Write(gzipFast(&b)). 然后你不需要取消注释:
//gz := gzip.NewWriter(w)
//defer gz.Close()
//json.NewEncoder(gz).Encode(box)
一切都是一个小例子,它显示了代码中发生的事情:
https://play.golang.org/p/6rzqLWTGiI
TA贡献1805条经验 获得超10个赞
我会避免[]byte手动压缩。您可以轻松地使用标准库中现有的编写器。另外,看看compress/flate我认为应该使用哪个而不是 gzip。
package main
import (
"net/http"
"encoding/json"
"compress/gzip"
"log"
)
type Box struct {
Width int `json:"width"`
}
func writeJsonResponseCompressed(w http.ResponseWriter, r *http.Request) {
box := &Box{Width: 10}
w.Header().Set("Content-Type", "application/json")
w.Header().Set("Content-Encoding", "gzip")
body, err := json.Marshal(box)
if err != nil {
// Your error handling
return
}
writer, err := gzip.NewWriterLevel(w, gzip.BestCompression)
if err != nil {
// Your error handling
return
}
defer writer.Close()
writer.Write(body)
}
func main() {
http.HandleFunc("/compressedget", writeJsonResponseCompressed)
log.Fatal(http.ListenAndServe(":8081", nil))
}
- 3 回答
- 0 关注
- 162 浏览
添加回答
举报