2 回答
TA贡献1878条经验 获得超4个赞
压缩到缓冲区并发布该缓冲区。
var buf bytes.Buffer
gz := gzip.NewWriter(&buf)
gz.Write(myJSON)
gz.Close()
因为a*bytes.Buffer是静态io.Reader接口,所以创建请求时可以直接使用缓冲区。
req, err := http.NewRequest("POST", url, &buf)
if err != nil {
// handle error
}
req.Header.Set("Content-Encoding", "gzip")
req.Header.Set("Content-Type", "application/json; charset=utf-8")
TA贡献1850条经验 获得超11个赞
最好的选择是将 JSON 编组流式传输到 gzip 编写器:
func compressJSON(w io.Writer, i interface{}) error {
gz := gzip.NewWriter(w)
if err := json.NewEncoder(gz).Encode(i); err != nil {
return err
}
return gz.Close()
}
这样做的好处是不会暂时在内存中缓冲 json,因此速度会更快并且使用更少的 RAM。
如果您需要将其作为io.Reader,例如 HTTP 请求的正文,则可以使用管道进行转换:
r, w := io.Pipe()
go func() {
err := compressJSON(w, someObject)
w.CloseWithError(err)
}()
req, err := http.NewRequest("POST", "http://example.com/", r)
- 2 回答
- 0 关注
- 90 浏览
添加回答
举报