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 關注
- 187 瀏覽
添加回答
舉報