Class UriComponentsBuilder
- All Implemented Interfaces:
- Cloneable, UriBuilder
- Direct Known Subclasses:
- ServletUriComponentsBuilder
UriComponents. Use as follows:
- Create a builder through a factory method, e.g. fromUriString(String).
- Set URI components (e.g. scheme, host, path, etc) through instance methods.
- Build the UriComponents.
- Expand URI variables from a map or array or variable values.
- Encode via UriComponents.encode().
- Use UriComponents.toUri()orUriComponents.toUriString().
By default, URI parsing is based on the RFC parser type,
which expects input strings to conform to RFC 3986 syntax. The alternative
WhatWG parser type, based on the algorithm from
the WhatWG URL Living Standard
provides more lenient handling of a wide range of cases that occur in user
types URL's.
- Since:
- 3.1
- Author:
- Arjen Poutsma, Rossen Stoyanchev, Phillip Webb, Oliver Gierke, Brian Clozel, Sebastien Deleuze, Sam Brannen
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumEnum to provide a choice of URI parsers to use infromUriString(String, ParserType).
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDefault constructor.protectedCreate a deep copy of the given UriComponentsBuilder.
- 
Method SummaryModifier and TypeMethodDescriptionbuild()Build aUriComponentsinstance from the various components contained in this builder.build(boolean encoded) Variant ofbuild()to create aUriComponentsinstance when components are already fully encoded.Build aURIinstance and replaces URI template variables with the values from an array.Build aURIinstance and replaces URI template variables with the values from a map.buildAndExpand(@Nullable Object... uriVariableValues) Build aUriComponentsinstance and replaces URI template variables with the values from an array.buildAndExpand(Map<String, ?> uriVariables) Build aUriComponentsinstance and replaces URI template variables with the values from a map.clone()Public declaration of Object'sclone()method.Clone thisUriComponentsBuilder.final UriComponentsBuilderencode()Request to have the URI template pre-encoded at build time, and URI variables encoded separately when expanded.A variant ofencode()with a charset other than "UTF-8".Set the URI fragment.static UriComponentsBuilderCreate a builder that is initialized with the given path.static UriComponentsBuilderCreate a builder that is initialized from the givenURI.static UriComponentsBuilderfromUriString(String uri) Variant offromUriString(String, ParserType)that defaults to theUriComponentsBuilder.ParserType.RFCparsing.static UriComponentsBuilderfromUriString(String uri, UriComponentsBuilder.ParserType parserType) Create a builder that is initialized by parsing the given URI string.Set the URI host which may contain URI template variables, and may also benullto clear the host of this builder.static UriComponentsBuilderCreate a new, empty builder.Append to the path of this builder.pathSegment(String... pathSegments) Append to the path using path segments.port(int port) Set the URI port.Set the URI port.Parse the given query string into query parameters, and append them to the query string.queryParam(String name, @Nullable Object... values) Append the given query parameter.queryParam(String name, @Nullable Collection<?> values) Variant ofUriBuilder.queryParam(String, Object...)with a Collection.queryParamIfPresent(String name, Optional<?> value) Delegates to eitherUriBuilder.queryParam(String, Object...)orUriBuilder.queryParam(String, Collection)if the givenOptionalhas a value, or else if it is empty, no query parameter is added at all.queryParams(@Nullable MultiValueMap<String, String> params) Add multiple query parameters and values.replacePath(@Nullable String path) Override the current path.replaceQuery(@Nullable String query) Clear existing query parameters and then delegate toUriBuilder.query(String).replaceQueryParam(String name, Object... values) Set the query parameter values replacing existing values, or if no values are given, the query parameter is removed.replaceQueryParam(String name, @Nullable Collection<?> values) Variant ofUriBuilder.replaceQueryParam(String, Object...)with a Collection.replaceQueryParams(@Nullable MultiValueMap<String, String> params) Set the query parameter values after removing all existing ones.Set the URI scheme which may contain URI template variables, and may also benullto clear the scheme of this builder.schemeSpecificPart(String ssp) Set the URI scheme-specific-part.Build a URI String.Initialize components of this builder from components of the given URI.uriComponents(UriComponents uriComponents) Set or append individual URI components of this builder from the values of the givenUriComponentsinstance.uriVariables(Map<String, Object> uriVariables) Configure URI variables to be expanded at build time.Set the URI user info which may contain URI template variables, and may also benullto clear the user info of this builder.
- 
Constructor Details- 
UriComponentsBuilderprotected UriComponentsBuilder()Default constructor. Protected to prevent direct instantiation.- See Also:
 
- 
UriComponentsBuilderCreate a deep copy of the given UriComponentsBuilder.- Parameters:
- other- the other builder to copy from
- Since:
- 4.1.3
 
 
- 
- 
Method Details- 
newInstanceCreate a new, empty builder.- Returns:
- the new UriComponentsBuilder
 
- 
fromPathCreate a builder that is initialized with the given path.- Parameters:
- path- the path to initialize with
- Returns:
- the new UriComponentsBuilder
 
- 
fromUriCreate a builder that is initialized from the givenURI.Note: the components in the resulting builder will be in fully encoded (raw) form and further changes must also supply values that are fully encoded, for example via methods in UriUtils. In addition please usebuild(boolean)with a value of "true" to build theUriComponentsinstance in order to indicate that the components are encoded.- Parameters:
- uri- the URI to initialize with
- Returns:
- the new UriComponentsBuilder
 
- 
fromUriStringVariant offromUriString(String, ParserType)that defaults to theUriComponentsBuilder.ParserType.RFCparsing.- Throws:
- InvalidUrlException
 
- 
fromUriStringpublic static UriComponentsBuilder fromUriString(String uri, UriComponentsBuilder.ParserType parserType) throws InvalidUrlException Create a builder that is initialized by parsing the given URI string.Note: The presence of reserved characters can prevent correct parsing of the URI string. For example if a query parameter contains '='or'&'characters, the query string cannot be parsed unambiguously. Such values should be substituted for URI variables to enable correct parsing:String uriString = "/hotels/42?filter={value}"; UriComponentsBuilder.fromUriString(uriString).buildAndExpand("hot&cold");- Parameters:
- uri- the URI string to initialize with
- parserType- the parsing algorithm to use
- Returns:
- the new UriComponentsBuilder
- Throws:
- InvalidUrlException- if- uricannot be parsed
- Since:
- 6.2
 
- 
encodeRequest to have the URI template pre-encoded at build time, and URI variables encoded separately when expanded.In comparison to UriComponents.encode(), this method has the same effect on the URI template, i.e. each URI component is encoded by replacing non-ASCII and illegal (within the URI component type) characters with escaped octets. However URI variables are encoded more strictly, by also escaping characters with reserved meaning.For most cases, this method is more likely to give the expected result because in treats URI variables as opaque data to be fully encoded, while UriComponents.encode()is useful when intentionally expanding URI variables that contain reserved characters.For example ';' is legal in a path but has reserved meaning. This method replaces ";" with "%3B" in URI variables but not in the URI template. By contrast, UriComponents.encode()never replaces ";" since it is a legal character in a path.When not expanding URI variables at all, prefer use of UriComponents.encode()since that will also encode anything that incidentally looks like a URI variable.- Since:
- 5.0.8
 
- 
encodeA variant ofencode()with a charset other than "UTF-8".- Parameters:
- charset- the charset to use for encoding
- Since:
- 5.0.8
 
- 
buildBuild aUriComponentsinstance from the various components contained in this builder.- Returns:
- the URI components
 
- 
buildVariant ofbuild()to create aUriComponentsinstance when components are already fully encoded. This is useful for example if the builder was created viafromUri(URI).- Parameters:
- encoded- whether the components in this builder are already encoded
- Returns:
- the URI components
- Throws:
- IllegalArgumentException- if any of the components contain illegal characters that should have been encoded.
 
- 
buildAndExpandBuild aUriComponentsinstance and replaces URI template variables with the values from a map. This is a shortcut method which combines calls tobuild()and thenUriComponents.expand(Map).- Parameters:
- uriVariables- the map of URI variables
- Returns:
- the URI components with expanded values
 
- 
buildAndExpandBuild aUriComponentsinstance and replaces URI template variables with the values from an array. This is a shortcut method which combines calls tobuild()and thenUriComponents.expand(Object...).- Parameters:
- uriVariableValues- the URI variable values
- Returns:
- the URI components with expanded values
 
- 
buildDescription copied from interface:UriBuilderBuild aURIinstance and replaces URI template variables with the values from an array.- Specified by:
- buildin interface- UriBuilder
- Parameters:
- uriVariables- the map of URI variables
- Returns:
- the URI
 
- 
buildDescription copied from interface:UriBuilderBuild aURIinstance and replaces URI template variables with the values from a map.- Specified by:
- buildin interface- UriBuilder
- Parameters:
- uriVariables- the map of URI variables
- Returns:
- the URI
 
- 
toUriStringBuild a URI String.Effectively, a shortcut for building, encoding, and returning the String representation: String uri = builder.build().encode().toUriString() However if URI variableshave been provided then the URI template is pre-encoded separately from URI variables (seeencode()for details), i.e. equivalent to:String uri = builder.encode().build().toUriString() - Specified by:
- toUriStringin interface- UriBuilder
- Since:
- 4.1
- See Also:
 
- 
uriInitialize components of this builder from components of the given URI.- Parameters:
- uri- the URI
- Returns:
- this UriComponentsBuilder
 
- 
uriComponentsSet or append individual URI components of this builder from the values of the givenUriComponentsinstance.For the semantics of each component (i.e. set vs append) check the builder methods on this class. For example host(String)sets whilepath(String)appends.- Parameters:
- uriComponents- the UriComponents to copy from
- Returns:
- this UriComponentsBuilder
 
- 
schemeDescription copied from interface:UriBuilderSet the URI scheme which may contain URI template variables, and may also benullto clear the scheme of this builder.- Specified by:
- schemein interface- UriBuilder
- Parameters:
- scheme- the URI scheme
 
- 
schemeSpecificPart
- 
userInfoDescription copied from interface:UriBuilderSet the URI user info which may contain URI template variables, and may also benullto clear the user info of this builder.- Specified by:
- userInfoin interface- UriBuilder
- Parameters:
- userInfo- the URI user info
 
- 
hostDescription copied from interface:UriBuilderSet the URI host which may contain URI template variables, and may also benullto clear the host of this builder.- Specified by:
- hostin interface- UriBuilder
- Parameters:
- host- the URI host
 
- 
portDescription copied from interface:UriBuilderSet the URI port. Passing-1will clear the port of this builder.- Specified by:
- portin interface- UriBuilder
- Parameters:
- port- the URI port
 
- 
portDescription copied from interface:UriBuilderSet the URI port. Use this method only when the port needs to be parameterized with a URI variable. Otherwise useUriBuilder.port(int). Passingnullwill clear the port of this builder.- Specified by:
- portin interface- UriBuilder
- Parameters:
- port- the URI port
 
- 
pathDescription copied from interface:UriBuilderAppend to the path of this builder.The given value is appended as-is to previous pathvalues without inserting any additional slashes. For example:builder.path("/first-").path("value/").path("/{id}").build("123") // Results is "/first-value/123"By contrast pathSegmentdoes insert slashes between individual path segments. For example:builder.pathSegment("first-value", "second-value").path("/") // Results is "/first-value/second-value/"The resulting full path is normalized to eliminate duplicate slashes. Note: When inserting a URI variable value that contains slashes in a path, whether those are encoded depends on the configured encoding mode. For more details, seeencode(), or otherwise if building URIs indirectly viaWebClientorRestTemplate, see itsencodingMode. Also see the URI Encoding section of the reference docs.- Specified by:
- pathin interface- UriBuilder
- Parameters:
- path- the URI path
 
- 
pathSegmentDescription copied from interface:UriBuilderAppend to the path using path segments. For example:builder.pathSegment("first-value", "second-value", "{id}").build("123") // Results is "/first-value/second-value/123"If slashes are present in a path segment, they are encoded: builder.pathSegment("ba/z", "{id}").build("a/b") // Results is "/ba%2Fz/a%2Fb"To insert a trailing slash, use theUriBuilder.path(String)builder method:builder.pathSegment("first-value", "second-value").path("/") // Results is "/first-value/second-value/"Empty path segments are ignored and therefore duplicate slashes do not appear in the resulting full path. - Specified by:
- pathSegmentin interface- UriBuilder
- Parameters:
- pathSegments- the URI path segments
- Throws:
- IllegalArgumentException
 
- 
replacePathDescription copied from interface:UriBuilderOverride the current path.- Specified by:
- replacePathin interface- UriBuilder
- Parameters:
- path- the URI path, or- nullfor an empty path
 
- 
queryDescription copied from interface:UriBuilderParse the given query string into query parameters, and append them to the query string. Query parameters are separated with'&'while their values, if any, are separated with'='. The query string may contain URI template variables.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- queryin interface- UriBuilder
- Parameters:
- query- the query string
 
- 
replaceQueryDescription copied from interface:UriBuilderClear existing query parameters and then delegate toUriBuilder.query(String).Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- replaceQueryin interface- UriBuilder
- Parameters:
- query- the query string; a- nullvalue removes all query parameters.
 
- 
queryParamDescription copied from interface:UriBuilderAppend the given query parameter. Both the parameter name and values may contain URI template variables to be expanded later from values. If no values are given, the resulting URI will contain the query parameter name only, for example,"?foo"instead of"?foo=bar".Note: encoding, if applied, will only encode characters that are illegal in a query parameter name or value such as "="or"&". All others that are legal as per syntax rules in RFC 3986 are not encoded. This includes"+"which sometimes needs to be encoded to avoid its interpretation as an encoded space. Stricter encoding may be applied by using a URI template variable along with stricter encoding on variable values. For more details please read the "URI Encoding" section of the Spring Framework reference.- Specified by:
- queryParamin interface- UriBuilder
- Parameters:
- name- the query parameter name
- values- the query parameter values
- See Also:
 
- 
queryParamDescription copied from interface:UriBuilderVariant ofUriBuilder.queryParam(String, Object...)with a Collection.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- queryParamin interface- UriBuilder
- Parameters:
- name- the query parameter name
- values- the query parameter values
- See Also:
 
- 
queryParamIfPresentDescription copied from interface:UriBuilderDelegates to eitherUriBuilder.queryParam(String, Object...)orUriBuilder.queryParam(String, Collection)if the givenOptionalhas a value, or else if it is empty, no query parameter is added at all.- Specified by:
- queryParamIfPresentin interface- UriBuilder
- Parameters:
- name- the query parameter name
- value- an Optional, either empty or holding the query parameter value.
 
- 
queryParamsAdd multiple query parameters and values.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- queryParamsin interface- UriBuilder
- Parameters:
- params- the params
- Since:
- 4.0
 
- 
replaceQueryParamDescription copied from interface:UriBuilderSet the query parameter values replacing existing values, or if no values are given, the query parameter is removed.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- replaceQueryParamin interface- UriBuilder
- Parameters:
- name- the query parameter name
- values- the query parameter values
- See Also:
 
- 
replaceQueryParamDescription copied from interface:UriBuilderVariant ofUriBuilder.replaceQueryParam(String, Object...)with a Collection.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- replaceQueryParamin interface- UriBuilder
- Parameters:
- name- the query parameter name
- values- the query parameter values
- See Also:
 
- 
replaceQueryParamsSet the query parameter values after removing all existing ones.Note: please, review the Javadoc of UriBuilder.queryParam(String, Object...)for further notes on the treatment and encoding of individual query parameters.- Specified by:
- replaceQueryParamsin interface- UriBuilder
- Parameters:
- params- the query parameter name
- Since:
- 4.2
 
- 
fragmentDescription copied from interface:UriBuilderSet the URI fragment. The given fragment may contain URI template variables, and may also benullto clear the fragment of this builder.- Specified by:
- fragmentin interface- UriBuilder
- Parameters:
- fragment- the URI fragment
 
- 
uriVariablesConfigure URI variables to be expanded at build time.The provided variables may be a subset of all required ones. At build time, the available ones are expanded, while unresolved URI placeholders are left in place and can still be expanded later. In contrast to UriComponents.expand(Map)orbuildAndExpand(Map), this method is useful when you need to supply URI variables without building theUriComponentsinstance just yet, or perhaps pre-expand some shared default values such as host and port.- Parameters:
- uriVariables- the URI variables to use
- Returns:
- this UriComponentsBuilder
- Since:
- 5.0.8
 
- 
clonePublic declaration of Object'sclone()method. Delegates tocloneBuilder().
- 
cloneBuilderClone thisUriComponentsBuilder.- Returns:
- the cloned UriComponentsBuilderobject
- Since:
- 4.2.7
 
 
-