reverseproxy: Restore request's original host and header (fix #3509)

We already restore them within the retry loop, but after successful
proxy we didn't reset them, so as handlers bubble back up, they would
see the values used for proxying.

Thanks to @ziddey for identifying the cause.
This commit is contained in:
Matthew Holt 2020-07-17 17:54:58 -06:00
parent 0665a86eb7
commit 246a31aacd
No known key found for this signature in database
GPG key ID: 2A349DD577D586A5

View file

@ -329,10 +329,17 @@ func (h *Handler) ServeHTTP(w http.ResponseWriter, r *http.Request, next caddyht
fmt.Errorf("preparing request for upstream round-trip: %v", err)) fmt.Errorf("preparing request for upstream round-trip: %v", err))
} }
// we will need the original headers and Host // we will need the original headers and Host value if
// value if header operations are configured // header operations are configured; and we should
reqHeader := r.Header // restore them after we're done if they are changed
// (for example, changing the outbound Host header
// should not permanently change r.Host; issue #3509)
reqHost := r.Host reqHost := r.Host
reqHeader := r.Header
defer func() {
r.Host = reqHost
r.Header = reqHeader
}()
start := time.Now() start := time.Now()