Class URIBuilder


  • public class URIBuilder
    extends Object
    Builder for URI instances.
    Since:
    4.2
    • Constructor Detail

      • URIBuilder

        public URIBuilder()
        Constructs an empty instance.
      • URIBuilder

        public URIBuilder​(String string)
                   throws URISyntaxException
        Construct an instance from the string which must be a valid URI.
        Parameters:
        string - a valid URI in string form
        Throws:
        URISyntaxException - if the input is not a valid URI
      • URIBuilder

        public URIBuilder​(URI uri)
        Construct an instance from the provided URI.
        Parameters:
        uri -
      • URIBuilder

        public URIBuilder​(String string,
                          Charset charset)
                   throws URISyntaxException
        Construct an instance from the string which must be a valid URI.
        Parameters:
        string - a valid URI in string form
        Throws:
        URISyntaxException - if the input is not a valid URI
      • URIBuilder

        public URIBuilder​(URI uri,
                          Charset charset)
        Construct an instance from the provided URI.
        Parameters:
        uri -
    • Method Detail

      • getCharset

        public Charset getCharset()
        Since:
        4.4
      • setUserInfo

        public URIBuilder setUserInfo​(String userInfo)
        Sets URI user info. The value is expected to be unescaped and may contain non ASCII characters.
      • setUserInfo

        public URIBuilder setUserInfo​(String username,
                                      String password)
        Sets URI user info as a combination of username and password. These values are expected to be unescaped and may contain non ASCII characters.
      • setPort

        public URIBuilder setPort​(int port)
        Sets URI port.
      • setPath

        public URIBuilder setPath​(String path)
        Sets URI path. The value is expected to be unescaped and may contain non ASCII characters.
        Returns:
        this.
      • setPathSegments

        public URIBuilder setPathSegments​(String... pathSegments)
        Sets URI path. The value is expected to be unescaped and may contain non ASCII characters.
        Returns:
        this.
        Since:
        4.5.8
      • setPathSegments

        public URIBuilder setPathSegments​(List<String> pathSegments)
        Sets URI path. The value is expected to be unescaped and may contain non ASCII characters.
        Returns:
        this.
        Since:
        4.5.8
      • removeQuery

        public URIBuilder removeQuery()
        Removes URI query.
      • setParameters

        public URIBuilder setParameters​(List<NameValuePair> nvps)
        Sets URI query parameters. The parameter name / values are expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove custom query if present.

        Since:
        4.3
      • addParameters

        public URIBuilder addParameters​(List<NameValuePair> nvps)
        Adds URI query parameters. The parameter name / values are expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove custom query if present.

        Since:
        4.3
      • setParameters

        public URIBuilder setParameters​(NameValuePair... nvps)
        Sets URI query parameters. The parameter name / values are expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove custom query if present.

        Since:
        4.3
      • addParameter

        public URIBuilder addParameter​(String param,
                                       String value)
        Adds parameter to URI query. The parameter name and value are expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove custom query if present.

      • setParameter

        public URIBuilder setParameter​(String param,
                                       String value)
        Sets parameter of URI query overriding existing value if set. The parameter name and value are expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove custom query if present.

      • clearParameters

        public URIBuilder clearParameters()
        Clears URI query parameters.
        Since:
        4.3
      • setCustomQuery

        public URIBuilder setCustomQuery​(String query)
        Sets custom URI query. The value is expected to be unescaped and may contain non ASCII characters.

        Please note query parameters and custom query component are mutually exclusive. This method will remove query parameters if present.

        Since:
        4.3
      • setFragment

        public URIBuilder setFragment​(String fragment)
        Sets URI fragment. The value is expected to be unescaped and may contain non ASCII characters.
      • isAbsolute

        public boolean isAbsolute()
        Since:
        4.3
      • isOpaque

        public boolean isOpaque()
        Since:
        4.3
      • getScheme

        public String getScheme()
      • getUserInfo

        public String getUserInfo()
      • getHost

        public String getHost()
      • getPort

        public int getPort()
      • isPathEmpty

        public boolean isPathEmpty()
        Since:
        4.5.8
      • getPathSegments

        public List<String> getPathSegments()
        Since:
        4.5.8
      • getPath

        public String getPath()
      • isQueryEmpty

        public boolean isQueryEmpty()
        Since:
        4.5.8
      • getFragment

        public String getFragment()