Consistent default encoding in DefaultUriBuilderFactory
Issue: SPR-17465
This commit is contained in:
parent
f5da737bd4
commit
e4c84ec757
|
|
@ -228,16 +228,14 @@ public class DefaultUriBuilderFactory implements UriBuilderFactory {
|
|||
}
|
||||
|
||||
private UriComponentsBuilder initUriComponentsBuilder(String uriTemplate) {
|
||||
|
||||
if (StringUtils.isEmpty(uriTemplate)) {
|
||||
return baseUri != null ? baseUri.cloneBuilder() : UriComponentsBuilder.newInstance();
|
||||
}
|
||||
|
||||
UriComponentsBuilder result;
|
||||
if (baseUri != null) {
|
||||
UriComponentsBuilder uricBuilder = UriComponentsBuilder.fromUriString(uriTemplate);
|
||||
UriComponents uric = uricBuilder.build();
|
||||
result = uric.getHost() == null ? baseUri.cloneBuilder().uriComponents(uric) : uricBuilder;
|
||||
if (StringUtils.isEmpty(uriTemplate)) {
|
||||
result = baseUri != null ? baseUri.cloneBuilder() : UriComponentsBuilder.newInstance();
|
||||
}
|
||||
else if (baseUri != null) {
|
||||
UriComponentsBuilder builder = UriComponentsBuilder.fromUriString(uriTemplate);
|
||||
UriComponents uri = builder.build();
|
||||
result = uri.getHost() == null ? baseUri.cloneBuilder().uriComponents(uri) : builder;
|
||||
}
|
||||
else {
|
||||
result = UriComponentsBuilder.fromUriString(uriTemplate);
|
||||
|
|
|
|||
|
|
@ -35,7 +35,14 @@ public class DefaultUriBuilderFactoryTests {
|
|||
@Test
|
||||
public void defaultSettings() {
|
||||
DefaultUriBuilderFactory factory = new DefaultUriBuilderFactory();
|
||||
URI uri = factory.uriString("/foo").pathSegment("{id}").build("a/b");
|
||||
URI uri = factory.uriString("/foo/{id}").build("a/b");
|
||||
assertEquals("/foo/a%2Fb", uri.toString());
|
||||
}
|
||||
|
||||
@Test // SPR-17465
|
||||
public void defaultSettingsWithBuilder() {
|
||||
DefaultUriBuilderFactory factory = new DefaultUriBuilderFactory();
|
||||
URI uri = factory.builder().path("/foo/{id}").build("a/b");
|
||||
assertEquals("/foo/a%2Fb", uri.toString());
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue