mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-25 07:49:19 -04:00 
			
		
		
		
	reverseproxy: Don't overwrite existing X-Forwarded-Proto header
Correct behavior is not well defined because this is a non-standard header field. This could be a "hop-by-hop" field much like X-Forwarded-For is, but even our X-Forwarded-For implementation preserves prior entries. Or, it could be best to preserve the original value from the first hop, representing the protocol as facing the client. Let's try it the other way for a bit and see how it goes. See https://caddy.community/t/caddy2-w-wordpress-behind-nginx-reverse-proxy/8174/3?u=matt
This commit is contained in:
		
							parent
							
								
									cc8fb488d3
								
							
						
					
					
						commit
						2a8a198568
					
				| @ -441,12 +441,14 @@ func (h Handler) prepareRequest(req *http.Request) error { | |||||||
| 		req.Header.Set("X-Forwarded-For", clientIP) | 		req.Header.Set("X-Forwarded-For", clientIP) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// set X-Forwarded-Proto; many backend apps expect this too | 	if req.Header.Get("X-Forwarded-Proto") == "" { | ||||||
| 	proto := "https" | 		// set X-Forwarded-Proto; many backend apps expect this too | ||||||
| 	if req.TLS == nil { | 		proto := "https" | ||||||
| 		proto = "http" | 		if req.TLS == nil { | ||||||
|  | 			proto = "http" | ||||||
|  | 		} | ||||||
|  | 		req.Header.Set("X-Forwarded-Proto", proto) | ||||||
| 	} | 	} | ||||||
| 	req.Header.Set("X-Forwarded-Proto", proto) |  | ||||||
| 
 | 
 | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user