Package org.eclipse.jetty.util
Class URIUtil
- java.lang.Object
- 
- org.eclipse.jetty.util.URIUtil
 
- 
- All Implemented Interfaces:
- java.lang.Cloneable
 
 public class URIUtil extends java.lang.Object implements java.lang.CloneableURI Utility methods.This class assists with the decoding and encoding or HTTP URI's. It differs from the java.net.URL class as it does not provide communications ability, but it does assist with query string formatting. - See Also:
- UrlEncoded
 
- 
- 
Method SummaryAll Methods Static Methods Concrete Methods Deprecated Methods Modifier and Type Method Description static java.lang.StringaddEncodedPaths(java.lang.String p1, java.lang.String p2)Add two encoded URI path segments.static java.net.URIaddPath(java.net.URI uri, java.lang.String path)static java.lang.StringaddPathQuery(java.lang.String path, java.lang.String query)Add a path and a query stringstatic java.lang.StringaddPaths(java.lang.String p1, java.lang.String p2)Add two Decoded URI path segments.static java.lang.StringaddQueries(java.lang.String query1, java.lang.String query2)Combine two query strings into one.static voidappendSchemeHostPort(java.lang.StringBuffer url, java.lang.String scheme, java.lang.String server, int port)Append scheme, host and port URI prefix, handling IPv6 address encoding and default portsstatic voidappendSchemeHostPort(java.lang.StringBuilder url, java.lang.String scheme, java.lang.String server, int port)Append scheme, host and port URI prefix, handling IPv6 address encoding and default portsstatic java.lang.StringcanonicalEncodedPath(java.lang.String path)Deprecated.static java.lang.StringcanonicalPath(java.lang.String path)Convert a decoded URI path to a canonical form.static java.lang.StringcanonicalURI(java.lang.String uri)Convert a partial URI to a canonical form.static java.lang.StringcompactPath(java.lang.String path)Convert a path to a compact form.static java.lang.StringdecodePath(java.lang.String path)static java.lang.StringdecodePath(java.lang.String path, int offset, int length)static java.lang.StringdecodeSpecific(java.lang.String str, java.lang.String charsToDecode)Decode a raw String and convert any specific URI encoded sequences into characters.static java.lang.StringencodePath(java.lang.String path)Encode a URI path.static java.lang.StringBuilderencodePath(java.lang.StringBuilder buf, java.lang.String path)Encode a URI path.static java.lang.StringencodeSpaces(java.lang.String str)Encode a raw URI String and convert any raw spaces to their "%20" equivalent.static java.lang.StringencodeSpecific(java.lang.String str, java.lang.String charsToEncode)Encode a raw String and convert any specific characters to their URI encoded equivalent.static java.lang.StringBuilderencodeString(java.lang.StringBuilder buf, java.lang.String path, java.lang.String encode)Encode a URI path.static booleanequalsIgnoreEncodings(java.lang.String uriA, java.lang.String uriB)static booleanequalsIgnoreEncodings(java.net.URI uriA, java.net.URI uriB)static java.lang.StringgetJarSource(java.lang.String uri)static java.net.URIgetJarSource(java.net.URI uri)static java.lang.StringgetUriLastPathSegment(java.net.URI uri)Given a URI, attempt to get the last segment.static booleanhasScheme(java.lang.String uri)static java.lang.StringnewURI(java.lang.String scheme, java.lang.String server, int port, java.lang.String path, java.lang.String query)Create a new URI from the arguments, handling IPv6 host encoding and default portsstatic java.lang.StringBuildernewURIBuilder(java.lang.String scheme, java.lang.String server, int port)Create a new URI StringBuilder from the arguments, handling IPv6 host encoding and default portsstatic java.lang.StringparentPath(java.lang.String p)Return the parent Path.
 
- 
- 
- 
Field Detail- 
SLASHpublic static final java.lang.String SLASH - See Also:
- Constant Field Values
 
 - 
HTTPpublic static final java.lang.String HTTP - See Also:
- Constant Field Values
 
 - 
HTTPSpublic static final java.lang.String HTTPS - See Also:
- Constant Field Values
 
 - 
__CHARSETpublic static final java.nio.charset.Charset __CHARSET 
 
- 
 - 
Method Detail- 
encodePathpublic static java.lang.String encodePath(java.lang.String path) Encode a URI path. This is the same encoding offered by URLEncoder, except that the '/' character is not encoded.- Parameters:
- path- The path the encode
- Returns:
- The encoded path
 
 - 
encodePathpublic static java.lang.StringBuilder encodePath(java.lang.StringBuilder buf, java.lang.String path)Encode a URI path.- Parameters:
- path- The path the encode
- buf- StringBuilder to encode path into (or null)
- Returns:
- The StringBuilder or null if no substitutions required.
 
 - 
encodeSpacespublic static java.lang.String encodeSpaces(java.lang.String str) Encode a raw URI String and convert any raw spaces to their "%20" equivalent.- Parameters:
- str- input raw string
- Returns:
- output with spaces converted to "%20"
 
 - 
encodeSpecificpublic static java.lang.String encodeSpecific(java.lang.String str, java.lang.String charsToEncode)Encode a raw String and convert any specific characters to their URI encoded equivalent.- Parameters:
- str- input raw string
- charsToEncode- the list of raw characters that need to be encoded (if encountered)
- Returns:
- output with specified characters encoded.
 
 - 
decodeSpecificpublic static java.lang.String decodeSpecific(java.lang.String str, java.lang.String charsToDecode)Decode a raw String and convert any specific URI encoded sequences into characters.- Parameters:
- str- input raw string
- charsToDecode- the list of raw characters that need to be decoded (if encountered), leaving all other encoded sequences alone.
- Returns:
- output with specified characters decoded.
 
 - 
encodeStringpublic static java.lang.StringBuilder encodeString(java.lang.StringBuilder buf, java.lang.String path, java.lang.String encode)Encode a URI path.- Parameters:
- path- The path the encode
- buf- StringBuilder to encode path into (or null)
- encode- String of characters to encode. % is always encoded.
- Returns:
- The StringBuilder or null if no substitutions required.
 
 - 
decodePathpublic static java.lang.String decodePath(java.lang.String path) 
 - 
decodePathpublic static java.lang.String decodePath(java.lang.String path, int offset, int length)
 - 
addEncodedPathspublic static java.lang.String addEncodedPaths(java.lang.String p1, java.lang.String p2)Add two encoded URI path segments. Handles null and empty paths, path and query params (eg ?a=b or ;JSESSIONID=xxx) and avoids duplicate '/'- Parameters:
- p1- URI path segment (should be encoded)
- p2- URI path segment (should be encoded)
- Returns:
- Legally combined path segments.
 
 - 
addPathspublic static java.lang.String addPaths(java.lang.String p1, java.lang.String p2)Add two Decoded URI path segments. Handles null and empty paths. Path and query params (eg ?a=b or ;JSESSIONID=xxx) are not handled- Parameters:
- p1- URI path segment (should be decoded)
- p2- URI path segment (should be decoded)
- Returns:
- Legally combined path segments.
 
 - 
addPathQuerypublic static java.lang.String addPathQuery(java.lang.String path, java.lang.String query)Add a path and a query string- Parameters:
- path- The path which may already contain contain a query
- query- The query string or null if no query to be added
- Returns:
- The path with any non null query added after a '?' or '&' as appropriate.
 
 - 
getUriLastPathSegmentpublic static java.lang.String getUriLastPathSegment(java.net.URI uri) Given a URI, attempt to get the last segment.If this is a jar:file://style URI, then the JAR filename is returned (not the deep!/pathlocation)- Parameters:
- uri- the URI to look in
- Returns:
- the last segment.
 
 - 
parentPathpublic static java.lang.String parentPath(java.lang.String p) Return the parent Path. Treat a URI like a directory path and return the parent directory.- Parameters:
- p- the path to return a parent reference to
- Returns:
- the parent path of the URI
 
 - 
canonicalURIpublic static java.lang.String canonicalURI(java.lang.String uri) Convert a partial URI to a canonical form.All segments of "." and ".." are factored out. Null is returned if the path tries to .. above its root. - Parameters:
- uri- the encoded URI from the path onwards, which may contain query strings and/or fragments
- Returns:
- the canonical path, or null if path traversal above root.
- See Also:
- canonicalPath(String)
 
 - 
canonicalEncodedPath@Deprecated public static java.lang.String canonicalEncodedPath(java.lang.String path) Deprecated.- Parameters:
- path- the encoded URI from the path onwards, which may contain query strings and/or fragments
- Returns:
- the canonical path, or null if path traversal above root.
 
 - 
canonicalPathpublic static java.lang.String canonicalPath(java.lang.String path) Convert a decoded URI path to a canonical form.All segments of "." and ".." are factored out. Null is returned if the path tries to .. above its root. - Parameters:
- path- the decoded URI path to convert. Any special characters (e.g. '?', "#") are assumed to be part of the path segments.
- Returns:
- the canonical path, or null if path traversal above root.
- See Also:
- canonicalURI(String)
 
 - 
compactPathpublic static java.lang.String compactPath(java.lang.String path) Convert a path to a compact form. All instances of "//" and "///" etc. are factored out to single "/"- Parameters:
- path- the path to compact
- Returns:
- the compacted path
 
 - 
hasSchemepublic static boolean hasScheme(java.lang.String uri) - Parameters:
- uri- URI
- Returns:
- True if the uri has a scheme
 
 - 
newURIpublic static java.lang.String newURI(java.lang.String scheme, java.lang.String server, int port, java.lang.String path, java.lang.String query)Create a new URI from the arguments, handling IPv6 host encoding and default ports- Parameters:
- scheme- the URI scheme
- server- the URI server
- port- the URI port
- path- the URI path
- query- the URI query
- Returns:
- A String URI
 
 - 
newURIBuilderpublic static java.lang.StringBuilder newURIBuilder(java.lang.String scheme, java.lang.String server, int port)Create a new URI StringBuilder from the arguments, handling IPv6 host encoding and default ports- Parameters:
- scheme- the URI scheme
- server- the URI server
- port- the URI port
- Returns:
- a StringBuilder containing URI prefix
 
 - 
appendSchemeHostPortpublic static void appendSchemeHostPort(java.lang.StringBuilder url, java.lang.String scheme, java.lang.String server, int port)Append scheme, host and port URI prefix, handling IPv6 address encoding and default ports- Parameters:
- url- StringBuilder to append to
- scheme- the URI scheme
- server- the URI server
- port- the URI port
 
 - 
appendSchemeHostPortpublic static void appendSchemeHostPort(java.lang.StringBuffer url, java.lang.String scheme, java.lang.String server, int port)Append scheme, host and port URI prefix, handling IPv6 address encoding and default ports- Parameters:
- url- StringBuffer to append to
- scheme- the URI scheme
- server- the URI server
- port- the URI port
 
 - 
equalsIgnoreEncodingspublic static boolean equalsIgnoreEncodings(java.lang.String uriA, java.lang.String uriB)
 - 
equalsIgnoreEncodingspublic static boolean equalsIgnoreEncodings(java.net.URI uriA, java.net.URI uriB)
 - 
addPathpublic static java.net.URI addPath(java.net.URI uri, java.lang.String path)- Parameters:
- uri- A URI to add the path to
- path- A decoded path element
- Returns:
- URI with path added.
 
 - 
addQueriespublic static java.lang.String addQueries(java.lang.String query1, java.lang.String query2)Combine two query strings into one. Each query string should not contain the beginning '?' character, but may contain multiple parameters separated by the '&' character.- Parameters:
- query1- the first query string.
- query2- the second query string.
- Returns:
- the combination of the two query strings.
 
 - 
getJarSourcepublic static java.net.URI getJarSource(java.net.URI uri) 
 - 
getJarSourcepublic static java.lang.String getJarSource(java.lang.String uri) 
 
- 
 
-