Skip to content

Commit f8ee28e

Browse files
committed
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
1 parent 0ed00a6 commit f8ee28e

File tree

2 files changed

+13
-1
lines changed

2 files changed

+13
-1
lines changed

web/src/main/java/org/springframework/security/web/server/savedrequest/WebSessionServerRequestCache.java

+3-1
Original file line numberDiff line numberDiff line change
@@ -86,6 +86,8 @@ public Mono<ServerHttpRequest> removeMatchingRequest(
8686
}
8787

8888
private static String pathInApplication(ServerHttpRequest request) {
89-
return request.getPath().pathWithinApplication().value();
89+
String path = request.getPath().pathWithinApplication().value();
90+
String query = request.getURI().getRawQuery();
91+
return path + (query != null ? "?" + query : "");
9092
}
9193
}

web/src/test/java/org/springframework/security/web/server/savedrequest/WebSessionServerRequestCacheTests.java

+10
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@
1717
package org.springframework.security.web.server.savedrequest;
1818

1919
import org.junit.Test;
20+
import org.springframework.http.MediaType;
2021
import org.springframework.http.server.reactive.ServerHttpRequest;
2122
import org.springframework.mock.http.server.reactive.MockServerHttpRequest;
2223
import org.springframework.mock.web.server.MockServerWebExchange;
@@ -44,6 +45,15 @@ public void saveRequestGetRequestWhenGetThenFound() {
4445
}
4546

4647
@Test
48+
public void saveRequestGetRequestWithQueryParamsWhenGetThenFound() {
49+
MockServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.get("/secured/").queryParam("key", "value").accept(MediaType.TEXT_HTML));
50+
this.cache.saveRequest(exchange).block();
51+
52+
URI saved = this.cache.getRedirectUri(exchange).block();
53+
54+
assertThat(saved).isEqualTo(exchange.getRequest().getURI());
55+
}
56+
4757
public void saveRequestGetRequestWhenPostThenNotFound() {
4858
MockServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.post("/secured/"));
4959
this.cache.saveRequest(exchange).block();

0 commit comments

Comments
 (0)