From 69662d4d7d37fc408a3792d3c54dd875a5c199e6 Mon Sep 17 00:00:00 2001 From: Tatsuhiko Kubo Date: Sat, 14 Nov 2015 05:59:38 +0900 Subject: [PATCH] gzip: added Vary: Accept-Encoding to response header. When the downstream is cache server or CDN, it is important. --- middleware/gzip/gzip.go | 1 + middleware/gzip/gzip_test.go | 3 +++ 2 files changed, 4 insertions(+) diff --git a/middleware/gzip/gzip.go b/middleware/gzip/gzip.go index 9acec5eb..e2d44775 100644 --- a/middleware/gzip/gzip.go +++ b/middleware/gzip/gzip.go @@ -47,6 +47,7 @@ outer: r.Header.Del("Accept-Encoding") w.Header().Set("Content-Encoding", "gzip") + w.Header().Set("Vary", "Accept-Encoding") gzipWriter, err := newWriter(c, w) if err != nil { // should not happen diff --git a/middleware/gzip/gzip_test.go b/middleware/gzip/gzip_test.go index 8d49e8e2..3e7bed99 100644 --- a/middleware/gzip/gzip_test.go +++ b/middleware/gzip/gzip_test.go @@ -87,6 +87,9 @@ func nextFunc(shouldGzip bool) middleware.Handler { if w.Header().Get("Content-Encoding") != "gzip" { return 0, fmt.Errorf("Content-Encoding must be gzip, found %v", r.Header.Get("Content-Encoding")) } + if w.Header().Get("Vary") != "Accept-Encoding" { + return 0, fmt.Errorf("Vary must be Accept-Encoding, found %v", r.Header.Get("Vary")) + } if _, ok := w.(gzipResponseWriter); !ok { return 0, fmt.Errorf("ResponseWriter should be gzipResponseWriter, found %T", w) }