mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-28 12:55:57 +03:00
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:
parent
0665a86eb7
commit
246a31aacd
1 changed files with 10 additions and 3 deletions
|
@ -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()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue