Commit 4a095590 authored by crvv's avatar crvv

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.
parent c8514ad7
...@@ -4,6 +4,7 @@ package templates ...@@ -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 ...@@ -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
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment