mirror of
https://github.com/spring-projects/spring-security.git
synced 2025-07-14 06:13:30 +00:00
Save query parameters in WebSessionServerRequestCache
Previously, URL query parameters were lost when saving a request in WebSessionServerRequestCache. Now it is properly saved and restored. Fixes: gh-6421
This commit is contained in:
parent
0ed00a6cde
commit
f8ee28ea9f
@ -86,6 +86,8 @@ public class WebSessionServerRequestCache implements ServerRequestCache {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static String pathInApplication(ServerHttpRequest request) {
|
private static String pathInApplication(ServerHttpRequest request) {
|
||||||
return request.getPath().pathWithinApplication().value();
|
String path = request.getPath().pathWithinApplication().value();
|
||||||
|
String query = request.getURI().getRawQuery();
|
||||||
|
return path + (query != null ? "?" + query : "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
package org.springframework.security.web.server.savedrequest;
|
package org.springframework.security.web.server.savedrequest;
|
||||||
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.springframework.http.MediaType;
|
||||||
import org.springframework.http.server.reactive.ServerHttpRequest;
|
import org.springframework.http.server.reactive.ServerHttpRequest;
|
||||||
import org.springframework.mock.http.server.reactive.MockServerHttpRequest;
|
import org.springframework.mock.http.server.reactive.MockServerHttpRequest;
|
||||||
import org.springframework.mock.web.server.MockServerWebExchange;
|
import org.springframework.mock.web.server.MockServerWebExchange;
|
||||||
@ -44,6 +45,15 @@ public class WebSessionServerRequestCacheTests {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
public void saveRequestGetRequestWithQueryParamsWhenGetThenFound() {
|
||||||
|
MockServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.get("/secured/").queryParam("key", "value").accept(MediaType.TEXT_HTML));
|
||||||
|
this.cache.saveRequest(exchange).block();
|
||||||
|
|
||||||
|
URI saved = this.cache.getRedirectUri(exchange).block();
|
||||||
|
|
||||||
|
assertThat(saved).isEqualTo(exchange.getRequest().getURI());
|
||||||
|
}
|
||||||
|
|
||||||
public void saveRequestGetRequestWhenPostThenNotFound() {
|
public void saveRequestGetRequestWhenPostThenNotFound() {
|
||||||
MockServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.post("/secured/"));
|
MockServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.post("/secured/"));
|
||||||
this.cache.saveRequest(exchange).block();
|
this.cache.saveRequest(exchange).block();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user