| java.lang.Object | |
| ↳ | java.net.URI | 
A Uniform Resource Identifier that identifies an abstract or physical resource, as specified by RFC 2396.
http://username:password@host:8080/directory/file?query#fragment
 | Component | Example value | Also known as | 
|---|---|---|
| Scheme | http | protocol | 
| Scheme-specific part | //username:password@host:8080/directory/file?query#fragment | |
| Authority | username:password@host:8080 | |
| User Info | username:password | |
| Host | host | |
| Port | 8080 | |
| Path | /directory/file | |
| Query | query | |
| Fragment | fragment | ref | 
absolute or relative.
 http://android.com/robots.txt
     robots.txt
 Absolute URIs always have a scheme. If its scheme is supported by URL, you can use toURL() to convert an absolute URI to a URL.
 
Relative URIs do not have a scheme and cannot be converted to URLs. If you
 have the absolute URI that a relative URI is relative to, you can use resolve(String) to compute the referenced absolute URI. Symmetrically, you can use
 relativize(URI) to compute the relative URI from one URI to another.
 
   URI absolute = new URI("http://android.com/");
   URI relative = new URI("robots.txt");
   URI resolved = new URI("http://android.com/robots.txt");
   // print "http://android.com/robots.txt"
   System.out.println(absolute.resolve(relative));
   // print "robots.txt"
   System.out.println(absolute.relativize(resolved));
 
 opaque or hierarchical. Relative
 URIs are always hierarchical.
 http://android.com/robots.txt
     mailto:robots@example.com
 Opaque URIs have both a scheme and a scheme-specific part that does not
 begin with the slash character: /. The contents of the
 scheme-specific part of an opaque URI is not parsed so an opaque URI never
 has an authority, user info, host, port, path or query. An opaque URIs may
 have a fragment, however. A typical opaque URI is
 mailto:robots@example.com.
 
| Component | Example value | 
|---|---|
| Scheme | mailto | 
| Scheme-specific part | robots@example.com | 
| Fragment | 
Hierarchical URIs may have values for any URL component. They always have a non-null path, though that path may be the empty string.
http://user:pa55w%3Frd@host:80/doc%7Csearch?q=green%20robots#over%206%22
 | Component | Legal Characters | Other Constraints | Raw Value | Value | 
|---|---|---|---|---|
| Scheme | 0-9,a-z,A-Z,+-. | First character must be in a-z,A-Z | http | |
| Scheme-specific part | 0-9,a-z,A-Z,_-!.~'()*,;:$&+=?/[]@ | Non-ASCII characters okay | //user:pa55w%3Frd@host:80/doc%7Csearch?q=green%20robots | //user:pa55w?rd@host:80/doc|search?q=green robots | 
| Authority | 0-9,a-z,A-Z,_-!.~'()*,;:$&+=@[] | Non-ASCII characters okay | user:pa55w%3Frd@host:80 | user:pa55w?rd@host:80 | 
| User Info | 0-9,a-z,A-Z,_-!.~'()*,;:$&+= | Non-ASCII characters okay | user:pa55w%3Frd | user:pa55w?rd | 
| Host | 0-9,a-z,A-Z,-.[] | Domain name, IPv4 address or [IPv6 address] | host | |
| Port | 0-9 | 80 | ||
| Path | 0-9,a-z,A-Z,_-!.~'()*,;:$&+=/@ | Non-ASCII characters okay | /doc%7Csearch | /doc|search | 
| Query | 0-9,a-z,A-Z,_-!.~'()*,;:$&+=?/[]@ | Non-ASCII characters okay | q=green%20robots | q=green robots | 
| Fragment | 0-9,a-z,A-Z,_-!.~'()*,;:$&+=?/[]@ | Non-ASCII characters okay | over%206%22 | over 6" | 
To encode a URI, invoke any of the multiple-parameter constructors of this class. These constructors accept your original strings and encode them into their raw form.
To decode a URI, invoke the single-string constructor, and then use the appropriate accessor methods to get the decoded components.
The URL class can be used to retrieve resources by their URI.
| Public Constructors | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Creates a new URI instance by parsing  spec. | |||||||||||
| Creates a new URI instance of the given unencoded component parts. | |||||||||||
| Creates a new URI instance of the given unencoded component parts. | |||||||||||
| Creates a new URI instance of the given unencoded component parts. | |||||||||||
| Creates a new URI instance of the given unencoded component parts. | |||||||||||
| Public Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
| Compares this URI with the given argument  uri. | |||||||||||
| Returns the URI formed by parsing  uri. | |||||||||||
| Compares this instance with the specified object and indicates if they
 are equal. | |||||||||||
| Returns the decoded authority part of this URI, or null if this URI has
 no authority. | |||||||||||
| Returns the decoded fragment of this URI, or null if this URI has no
 fragment. | |||||||||||
| Returns the host of this URI, or null if this URI has no host. | |||||||||||
| Returns the decoded path of this URI, or null if this URI has no path. | |||||||||||
| Returns the port number of this URI, or  -1if this URI has no
 explicit port. | |||||||||||
| Returns the decoded query of this URI, or null if this URI has no query. | |||||||||||
| Returns the encoded authority of this URI, or null if this URI has no
 authority. | |||||||||||
| Gets the encoded fragment of this URI, or null if this URI has no
 fragment. | |||||||||||
| Returns the encoded path of this URI, or null if this URI has no path. | |||||||||||
| Returns the encoded query of this URI, or null if this URI has no query. | |||||||||||
| Returns the encoded scheme-specific part of this URI, or null if this URI
 has no scheme-specific part. | |||||||||||
| Returns the encoded user info of this URI, or null if this URI has no
 user info. | |||||||||||
| Returns the scheme of this URI, or null if this URI has no scheme. | |||||||||||
| Returns the decoded scheme-specific part of this URI, or null if this URI
 has no scheme-specific part. | |||||||||||
| Returns the decoded user info of this URI, or null if this URI has no
 user info. | |||||||||||
| Returns an integer hash code for this object. | |||||||||||
| Returns true if this URI is absolute, which means that a scheme is
 defined. | |||||||||||
| Returns true if this URI is opaque. | |||||||||||
| Normalizes the path part of this URI. | |||||||||||
| Tries to parse the authority component of this URI to divide it into the
 host, port, and user-info. | |||||||||||
| Makes the given URI  relativeto a relative URI against the URI
 represented by this instance. | |||||||||||
| Creates a new URI instance by parsing the given string  relativeand resolves the created URI against the URI represented by this
 instance. | |||||||||||
| Resolves the given URI  relativeagainst the URI represented by
 this instance. | |||||||||||
| Returns the textual string representation of this URI instance using the
 US-ASCII encoding. | |||||||||||
| Returns the encoded URI. | |||||||||||
| Converts this URI instance to a URL. | |||||||||||
| [Expand] Inherited Methods | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|
|  From class
  java.lang.Object | |||||||||||
|  From interface
  java.lang.Comparable | |||||||||||
Creates a new URI instance by parsing spec.
| spec | a URI whose illegal characters have all been encoded. | 
|---|
| URISyntaxException | 
|---|
Creates a new URI instance of the given unencoded component parts.
| scheme | the URI scheme, or null for a non-absolute URI. | 
|---|
| URISyntaxException | 
|---|
Creates a new URI instance of the given unencoded component parts.
| scheme | the URI scheme, or null for a non-absolute URI. | 
|---|
| URISyntaxException | 
|---|
Creates a new URI instance of the given unencoded component parts.
| scheme | the URI scheme, or null for a non-absolute URI. | 
|---|
| URISyntaxException | 
|---|
Creates a new URI instance of the given unencoded component parts.
| scheme | the URI scheme, or null for a non-absolute URI. | 
|---|
| URISyntaxException | 
|---|
Compares this URI with the given argument uri. This method will
 return a negative value if this URI instance is less than the given
 argument and a positive value if this URI instance is greater than the
 given argument. The return value 0 indicates that the two
 instances represent the same URI. To define the order the single parts of
 the URI are compared with each other. String components will be ordered
 in the natural case-sensitive way. A hierarchical URI is less than an
 opaque URI and if one part is null the URI with the undefined
 part is less than the other one.
| uri | the URI this instance has to compare with. | 
|---|
Returns the URI formed by parsing uri. This method behaves
 identically to the string constructor but throws a different exception
 on failure. The constructor fails with a checked URISyntaxException; this method fails with an unchecked IllegalArgumentException.
Compares this instance with the specified object and indicates if they
 are equal. In order to be equal, o must represent the same object
 as this instance using a class-specific comparison. The general contract
 is that this comparison should be reflexive, symmetric, and transitive.
 Also, no object reference other than null is equal to null.
 
The default implementation returns true only if this ==
 o. See Writing a correct
 equals method
 if you intend implementing your own equals method.
 
The general contract for the equals and hashCode() methods is that if equals returns true for
 any two objects, then hashCode() must return the same value for
 these objects. This means that subclasses of Object usually
 override either both methods or neither of them.
| o | the object to compare this instance with. | 
|---|
true if the specified object is equal to this Object; false otherwise.Returns the decoded authority part of this URI, or null if this URI has no authority.
Returns the decoded fragment of this URI, or null if this URI has no fragment.
Returns the host of this URI, or null if this URI has no host.
Returns the decoded path of this URI, or null if this URI has no path.
Returns the port number of this URI, or -1 if this URI has no
 explicit port.
Returns the decoded query of this URI, or null if this URI has no query.
Returns the encoded authority of this URI, or null if this URI has no authority.
Gets the encoded fragment of this URI, or null if this URI has no fragment.
Returns the encoded path of this URI, or null if this URI has no path.
Returns the encoded query of this URI, or null if this URI has no query.
Returns the encoded scheme-specific part of this URI, or null if this URI has no scheme-specific part.
Returns the encoded user info of this URI, or null if this URI has no user info.
Returns the scheme of this URI, or null if this URI has no scheme. This is also known as the protocol.
Returns the decoded scheme-specific part of this URI, or null if this URI has no scheme-specific part.
Returns the decoded user info of this URI, or null if this URI has no user info.
Returns an integer hash code for this object. By contract, any two
 objects for which equals(Object) returns true must return
 the same hash code value. This means that subclasses of Object
 usually override both methods or neither method.
 
Note that hash values must not change over time unless information used in equals comparisons also changes.
See Writing a correct
 hashCode method
 if you intend implementing your own hashCode method.
Returns true if this URI is absolute, which means that a scheme is defined.
Returns true if this URI is opaque. Opaque URIs are absolute and have a scheme-specific part that does not start with a slash character. All parts except scheme, scheme-specific and fragment are undefined.
Normalizes the path part of this URI.
Tries to parse the authority component of this URI to divide it into the host, port, and user-info. If this URI is already determined as a ServerAuthority this instance will be returned without changes.
| URISyntaxException | if the authority part could not be parsed as a server-based authority. | 
|---|
Makes the given URI relative to a relative URI against the URI
 represented by this instance.
| relative | the URI which has to be relativized against this URI. | 
|---|
Creates a new URI instance by parsing the given string relative
 and resolves the created URI against the URI represented by this
 instance.
| relative | the given string to create the new URI instance which has to be resolved later on. | 
|---|
Resolves the given URI relative against the URI represented by
 this instance.
| relative | the URI which has to be resolved against this URI. | 
|---|
Returns the textual string representation of this URI instance using the US-ASCII encoding.
Returns the encoded URI.
Converts this URI instance to a URL.
| MalformedURLException | if an error occurs while creating the URL or no protocol handler could be found. | 
|---|