|
@@ -1,5 +1,5 @@
|
|
|
/*
|
|
|
- * Copyright 2020-2022 the original author or authors.
|
|
|
+ * Copyright 2020-2023 the original author or authors.
|
|
|
*
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
* you may not use this file except in compliance with the License.
|
|
@@ -66,6 +66,9 @@ import org.springframework.security.web.util.matcher.RequestMatcher;
|
|
|
import org.springframework.util.Assert;
|
|
|
import org.springframework.util.StringUtils;
|
|
|
import org.springframework.web.filter.OncePerRequestFilter;
|
|
|
+import org.springframework.web.util.DefaultUriBuilderFactory;
|
|
|
+import org.springframework.web.util.UriBuilder;
|
|
|
+import org.springframework.web.util.UriBuilderFactory;
|
|
|
import org.springframework.web.util.UriComponentsBuilder;
|
|
|
|
|
|
/**
|
|
@@ -296,8 +299,8 @@ public final class OAuth2AuthorizationEndpointFilter extends OncePerRequestFilte
|
|
|
|
|
|
OAuth2AuthorizationCodeRequestAuthenticationToken authorizationCodeRequestAuthentication =
|
|
|
(OAuth2AuthorizationCodeRequestAuthenticationToken) authentication;
|
|
|
- UriComponentsBuilder uriBuilder = UriComponentsBuilder
|
|
|
- .fromUriString(authorizationCodeRequestAuthentication.getRedirectUri())
|
|
|
+ UriBuilder uriBuilder = valuesOnlyEncodingUriBuilderFactory()
|
|
|
+ .uriString(authorizationCodeRequestAuthentication.getRedirectUri())
|
|
|
.queryParam(OAuth2ParameterNames.CODE, authorizationCodeRequestAuthentication.getAuthorizationCode().getTokenValue());
|
|
|
String redirectUri;
|
|
|
if (StringUtils.hasText(authorizationCodeRequestAuthentication.getState())) {
|
|
@@ -306,7 +309,7 @@ public final class OAuth2AuthorizationEndpointFilter extends OncePerRequestFilte
|
|
|
queryParams.put(OAuth2ParameterNames.STATE, authorizationCodeRequestAuthentication.getState());
|
|
|
redirectUri = uriBuilder.build(queryParams).toString();
|
|
|
} else {
|
|
|
- redirectUri = uriBuilder.toUriString();
|
|
|
+ redirectUri = uriBuilder.build().toString();
|
|
|
}
|
|
|
this.redirectStrategy.sendRedirect(request, response, redirectUri);
|
|
|
}
|
|
@@ -351,6 +354,12 @@ public final class OAuth2AuthorizationEndpointFilter extends OncePerRequestFilte
|
|
|
this.redirectStrategy.sendRedirect(request, response, redirectUri);
|
|
|
}
|
|
|
|
|
|
+ private UriBuilderFactory valuesOnlyEncodingUriBuilderFactory() {
|
|
|
+ DefaultUriBuilderFactory uriBuilderFactory = new DefaultUriBuilderFactory();
|
|
|
+ uriBuilderFactory.setEncodingMode(DefaultUriBuilderFactory.EncodingMode.VALUES_ONLY);
|
|
|
+ return uriBuilderFactory;
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* For internal use only.
|
|
|
*/
|