An enum
encapsulating any of the possible URI variants.
In Rocket, this type will rarely be used directly. Instead, you will
typically encounter URIs via the Origin
type. This is because all
incoming requests contain origin-type URIs.
Nevertheless, the Uri
type is typically enountered as a conversion target.
In particular, you will likely see generic bounds of the form: T: TryInto<Uri>
(for instance, in Redirect
methods). This means that you can provide any type T
that implements
TryInto<Uri>
, or, equivalently, any type U
for which Uri
implements
TryFrom<U>
or From<U>
. These include &str
and String
, Origin
,
Authority
, and Absolute
.
The Uri
type implements a full, zero-allocation, zero-copy RFC 7230
compliant parser. To parse an &str
into a Uri
, use the Uri::parse()
method. Alternatively, you may also use the TryFrom<&str>
and
TryFrom<String>
trait implementation. To inspect the parsed type, match on
the resulting enum
and use the methods of the internal structure.
This type also provides the following percent encoding/decoding helper
methods: Uri::percent_encode()
, Uri::percent_decode()
, and
Uri::percent_decode_lossy()
.
Parses the string string
into a Uri
. Parsing will never allocate.
Returns an Error
if string
is not a valid URI.
use rocket::http::uri::Uri;
let uri = Uri::parse("/a/b/c?query").expect("valid URI");
let origin = uri.origin().expect("origin URI");
assert_eq!(origin.path(), "/a/b/c");
assert_eq!(origin.query(), Some("query"));
Uri::parse("foo bar").expect_err("invalid URI");
Returns the internal instance of Origin
if self
is a Uri::Origin
.
Otherwise, returns None
.
use rocket::http::uri::Uri;
let uri = Uri::parse("/a/b/c?query").expect("valid URI");
assert!(uri.origin().is_some());
let uri = Uri::parse("http://google.com").expect("valid URI");
assert!(uri.origin().is_none());
Returns the internal instance of Authority
if self
is a
Uri::Authority
. Otherwise, returns None
.
use rocket::http::uri::Uri;
let uri = Uri::parse("user:pass@domain.com").expect("valid URI");
assert!(uri.authority().is_some());
let uri = Uri::parse("http://google.com").expect("valid URI");
assert!(uri.authority().is_none());
Returns the internal instance of Absolute
if self
is a
Uri::Absolute
. Otherwise, returns None
.
use rocket::http::uri::Uri;
let uri = Uri::parse("http://google.com").expect("valid URI");
assert!(uri.absolute().is_some());
let uri = Uri::parse("/path").expect("valid URI");
assert!(uri.absolute().is_none());
Returns a URL-encoded version of the string. Any characters outside of
visible ASCII-range are encoded as well as ' ', '"', '#', '<', '>', '`',
'?', '{', '}', '%', '/', '[', '\', ']', '^', and '|'.
use rocket::http::uri::Uri;
let encoded = Uri::percent_encode("hello?a=<b>hi</b>");
assert_eq!(encoded, "hello%3Fa=%3Cb%3Ehi%3C%2Fb%3E");
Returns a URL-decoded version of the string. If the percent encoded
values are not valid UTF-8, an Err
is returned.
use rocket::http::uri::Uri;
let decoded = Uri::percent_decode("/Hello%2C%20world%21".as_bytes());
assert_eq!(decoded.unwrap(), "/Hello, world!");
Returns a URL-decoded version of the path. Any invalid UTF-8
percent-encoded byte sequences will be replaced � U+FFFD, the
replacement character.
use rocket::http::uri::Uri;
let decoded = Uri::percent_decode_lossy("/Hello%2C%20world%21".as_bytes());
assert_eq!(decoded, "/Hello, world!");
type Owned = Uri<'static>
The owned version of the type.
Converts self
into an owned version of itself.
This method tests for self
and other
values to be equal, and is used by ==
. Read more
This method tests for !=
.
Performs copy-assignment from source
. Read more
Formats the value using the given formatter. Read more
Formats the value using the given formatter. Read more
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
Converts self
into a collection.
type Owned = T
Creates owned data from borrowed data, usually by cloning. Read more
🔬 This is a nightly-only experimental API. (toowned_clone_into
)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
Converts the given value to a String
. Read more
type Error = !
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (try_from
)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (try_from
)
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static
Get the TypeId
of this object.