Commit a2dbfdc1 authored by Matt Holt's avatar Matt Holt

Merge pull request #636 from humboldtux/fastcgi-cl

fastcgi: Explicitly set Content-Length (fixes #626)
parents 05957b49 ef5f9c77
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
package fastcgi package fastcgi
import ( import (
"bytes"
"errors" "errors"
"io" "io"
"net/http" "net/http"
...@@ -105,13 +106,21 @@ func (h Handler) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error) ...@@ -105,13 +106,21 @@ func (h Handler) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error)
return http.StatusBadGateway, err return http.StatusBadGateway, err
} }
// Write the response body to a buffer
// To explicitly set Content-Length
// For FastCGI app that don't set it
var buf bytes.Buffer
io.Copy(&buf, resp.Body)
if r.Header.Get("Content-Length") == "" {
w.Header().Set("Content-Length", strconv.Itoa(buf.Len()))
}
writeHeader(w, resp) writeHeader(w, resp)
// Write the response body // Write the response body
// TODO: If this has an error, the response will already be // TODO: If this has an error, the response will already be
// partly written. We should copy out of resp.Body into a buffer // partly written. We should copy out of resp.Body into a buffer
// first, then write it to the response... // first, then write it to the response...
_, err = io.Copy(w, resp.Body) _, err = io.Copy(w, &buf)
if err != nil { if err != nil {
return http.StatusBadGateway, err return http.StatusBadGateway, err
} }
......
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