templates: Set right response Content-Type

If use gzip and templates at the same time, the response body will
be gzipped data. And in this case, the Content-Type header won't be
set by Caddy code. Then Go http package will set "Content-Type" to
wrong value "application/x-gzip" which is determined by response body.
So the header Contenty-Type should be set in templates middleware.
This commit is contained in:
crvv 2017-02-28 18:14:52 +08:00
parent c8514ad7b7
commit 4a095590b1

View file

@ -4,6 +4,7 @@ package templates
import ( import (
"bytes" "bytes"
"mime"
"net/http" "net/http"
"os" "os"
"path" "path"
@ -62,6 +63,16 @@ func (t Templates) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error
return http.StatusInternalServerError, err return http.StatusInternalServerError, err
} }
// If Content-Type isn't set here, http.ResponseWriter.Write
// will set it according to response body. But other middleware
// such as gzip can modify response body, then Content-Type
// detected by http.ResponseWriter.Write is wrong.
ctype := mime.TypeByExtension(ext)
if ctype == "" {
ctype = http.DetectContentType(buf.Bytes())
}
w.Header().Set("Content-Type", ctype)
templateInfo, err := os.Stat(templatePath) templateInfo, err := os.Stat(templatePath)
if err == nil { if err == nil {
// add the Last-Modified header if we were able to read the stamp // add the Last-Modified header if we were able to read the stamp