Full "Forwarded" header support including port number
Issue: SPR-15504
This commit is contained in:
committed by
Rossen Stoyanchev
parent
2ccf78743a
commit
ec55e429f0
@@ -790,4 +790,59 @@ public class UriComponentsBuilderTests {
|
||||
assertEquals("/rest/mobile/users/1", result.getPath());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void fromHttpRequestForwardedHeaderWithHostPortAndWithoutServerPort() throws Exception {
|
||||
MockHttpServletRequest request = new MockHttpServletRequest();
|
||||
request.addHeader("Forwarded", "proto=https; host=84.198.58.199:9090");
|
||||
request.setScheme("http");
|
||||
request.setServerName("example.com");
|
||||
request.setRequestURI("/rest/mobile/users/1");
|
||||
|
||||
HttpRequest httpRequest = new ServletServerHttpRequest(request);
|
||||
UriComponents result = UriComponentsBuilder.fromHttpRequest(httpRequest).build();
|
||||
|
||||
assertEquals("https", result.getScheme());
|
||||
assertEquals("84.198.58.199", result.getHost());
|
||||
assertEquals("/rest/mobile/users/1", result.getPath());
|
||||
assertEquals(9090, result.getPort());
|
||||
assertEquals("https://84.198.58.199:9090/rest/mobile/users/1", result.toUriString());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void fromHttpRequestForwardedHeaderWithHostPortAndServerPort() throws Exception {
|
||||
MockHttpServletRequest request = new MockHttpServletRequest();
|
||||
request.addHeader("Forwarded", "proto=https; host=84.198.58.199:9090");
|
||||
request.setScheme("http");
|
||||
request.setServerPort(8080);
|
||||
request.setServerName("example.com");
|
||||
request.setRequestURI("/rest/mobile/users/1");
|
||||
|
||||
HttpRequest httpRequest = new ServletServerHttpRequest(request);
|
||||
UriComponents result = UriComponentsBuilder.fromHttpRequest(httpRequest).build();
|
||||
|
||||
assertEquals("https", result.getScheme());
|
||||
assertEquals("84.198.58.199", result.getHost());
|
||||
assertEquals("/rest/mobile/users/1", result.getPath());
|
||||
assertEquals(9090, result.getPort());
|
||||
assertEquals("https://84.198.58.199:9090/rest/mobile/users/1", result.toUriString());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void fromHttpRequestForwardedHeaderWithoutHostPortAndWithServerPort() throws Exception {
|
||||
MockHttpServletRequest request = new MockHttpServletRequest();
|
||||
request.addHeader("Forwarded", "proto=https; host=84.198.58.199");
|
||||
request.setScheme("http");
|
||||
request.setServerPort(8080);
|
||||
request.setServerName("example.com");
|
||||
request.setRequestURI("/rest/mobile/users/1");
|
||||
|
||||
HttpRequest httpRequest = new ServletServerHttpRequest(request);
|
||||
UriComponents result = UriComponentsBuilder.fromHttpRequest(httpRequest).build();
|
||||
|
||||
assertEquals("https", result.getScheme());
|
||||
assertEquals("84.198.58.199", result.getHost());
|
||||
assertEquals("/rest/mobile/users/1", result.getPath());
|
||||
assertEquals(-1, result.getPort());
|
||||
assertEquals("https://84.198.58.199/rest/mobile/users/1", result.toUriString());
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user