Go标准库支持HTTP压缩与解压,客户端需手动压缩请求体并设置Content-Encoding: gzip,服务端需解析该头并用gzip.NewReader解压;响应方面,客户端默认自动解压gzip,服务端则需根据Accept-Encoding手动压缩并写入Content-Encoding头,通过中间件可实现请求解压与响应压缩。

Go语言标准库提供了对HTTP请求压缩与解压的原生支持,开发者无需引入第三方库即可实现高效的数据压缩传输。关键在于正确设置请求头和处理响应体的gzip解码。
Go默认不会压缩请求体,但可以通过手动启用gzip压缩来减少上传数据量。适用于POST、PUT等携带大量数据的请求。
步骤如下:
var buf bytes.Buffer
gz := gzip.NewWriter(&buf)
gz.Write([]byte("your large payload"))
gz.Close()
req, _ := http.NewRequest("POST", "http://example.com", &buf)
req.Header.Set("Content-Encoding", "gzip")
req.Header.Set("Content-Type", "application/json")
client := &http.Client{}
resp, _ := client.Do(req)
net/http包默认启用了对gzip和deflate响应的自动解压功能。只要服务端返回的响应头包含Content-Encoding: gzip,Client.Do会自动解压Body内容。
立即学习“go语言免费学习笔记(深入)”;
你只需要像处理普通响应一样读取Body即可:
resp, _ := http.Get("http://api.example.com/data")
body, _ := io.ReadAll(resp.Body)
// body已经是解压后的数据
若需关闭自动解压,可自定义Transport:
client := &http.Client{
Transport: &http.Transport{
DisableCompression: true,
},
}
服务端需要主动检查请求头中的Content-Encoding,并对Body进行相应解压。
常见做法:
func gzipMiddleware(next http.HandlerFunc) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
if r.Header.Get("Content-Encoding") == "gzip" {
reader, err := gzip.NewReader(r.Body)
if err != nil {
http.Error(w, "invalid gzip", http.StatusBadRequest)
return
}
defer reader.Close()
r.Body = reader
}
next(w, r)
}
}
Go标准库不自动压缩响应,需手动实现。可通过包装ResponseWriter拦截Write调用,并根据Accept-Encoding决定是否启用gzip压缩。
基本思路:
可借助第三方库如github.com/gin-gonic/contrib/gzip(Gin框架)或自行实现中间件。
基本上就这些。标准库提供了足够基础组件,合理组合即可完成完整的压缩解压流程。注意资源释放和错误处理,避免内存泄漏。以上就是Golang如何处理HTTP请求压缩与解压的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号