当前位置: > > > > 如何保留 HTTP 正文的 gzip 表示
来源:stackoverflow
2024-04-30 21:27:34
0浏览
收藏
今天给大家带来了《如何保留 HTTP 正文的 gzip 表示》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~
问题内容
在 go web 应用程序的上下文中,我使用响应缓存并压缩它们,因此我节省了带宽(响应更大)。我正在使用 gin-gonic
框架和包 gzip
进行压缩。这个包工作得很好,可以满足我接收和回复 gzip 压缩正文所需的一切。这几行就足够了:
router := gin.Default() router.Use(gzip.Gzip(gzip.DefaultCompression))
一切都很神奇。现在,我还使用存储响应的缓存。为了节省空间和cpu,我想将已经压缩的响应存储在缓存中,所以我也不重复压缩。作为包装 http 正文处理的中间件,gzip
透明地解压缩请求并压缩响应。然而,在我的处理程序级别,我希望获得响应的压缩表示,以便我可以将其存储到我的缓存中。另外,我需要告诉 gzip
我的身体已经被压缩了。
我已经进行了一些搜索,寻找一种使用 gzip
包或任何其他包的自动化方法,这可以防止我干预某些库、http 堆栈中的执行路径,或者最糟糕的是,自己对其他库已经制作的东西进行编程比如gzip
。
有人知道 gzip
包如何解决这个问题吗?
解决方案
首先,我继续使用 gzip
和 gin
软件包。
现在,我使用与此类似的函数来压缩我的响应:
func compress(response interface{}) ([]byte, error) { body, err := json.marshal(response) if err != nil { return nil, err } var buffer bytes.buffer zw := gzip.newwriter(&buffer) _, err = zw.write(body) closeerr := zw.close() if err != nil { return nil, err } if closeerr != nil { return nil, err } return buffer.bytes(), nil }
当我需要响应请求时,我执行如下操作:
gzipOutput, err := compressResponse(output) if err != nil { c.JSON(http.StatusInternalServerError, err.Error()) return } c.Writer.Header().Set("Accept-Encoding", "gzip") c.Writer.Header().Set("Content-Encoding", "gzip") c.Writer.Header().Set("Content-Type", "application/json") c.Data(http.StatusOK, "gzip", gzipOutput)
正如我们所看到的,其想法是告诉 gin
通过设置 html 标头来压缩响应。
自八个月以来,它已经在五个不同的 api 上进行了测试。
我希望它对其他人有用,就像对我有用一样。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何保留 HTTP 正文的 gzip 表示》文章吧,也可关注公众号了解相关技术文章。