pub struct HeaderMap<'h> { /* fields omitted */ }A collection of headers, mapping a header name to its many ordered values.
All header names, including those passed in to HeaderMap methods and those
stored in an existing HeaderMap, are treated case-insensitively. This
means that, for instance, a look for a header by the name of "aBC" will
returns values for headers of names "AbC", "ABC", "abc", and so on.
Returns an empty collection.
use rocket::http::HeaderMap;
let map = HeaderMap::new();
Returns true if self contains a header with the name name.
use rocket::http::{HeaderMap, ContentType};
let mut map = HeaderMap::new();
map.add(ContentType::HTML);
assert!(map.contains("Content-Type"));
assert!(!map.contains("Accepts"));
Returns the number of values stored in the map.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
assert_eq!(map.len(), 0);
map.add_raw("X-Custom", "value_1");
assert_eq!(map.len(), 1);
map.replace_raw("X-Custom", "value_2");
assert_eq!(map.len(), 1);
map.add_raw("X-Custom", "value_1");
assert_eq!(map.len(), 2);
Returns true if there are no headers stored in the map. Otherwise
returns false.
use rocket::http::HeaderMap;
let map = HeaderMap::new();
assert!(map.is_empty());
Returns an iterator over all of the values stored in self for the
header with name name. The headers are returned in FIFO order.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
map.add_raw("X-Custom", "value_2");
assert_eq!(map.len(), 2);
let mut values = map.get("X-Custom");
assert_eq!(values.next(), Some("value_1"));
assert_eq!(values.next(), Some("value_2"));
assert_eq!(values.next(), None);
Returns the first value stored for the header with name name if
there is one.
Retrieve the first value when one exists:
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
map.add_raw("X-Custom", "value_2");
assert_eq!(map.len(), 2);
let first_value = map.get_one("X-Custom");
assert_eq!(first_value, Some("value_1"));
Attempt to retrieve a value that doesn't exist:
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
let first_value = map.get_one("X-Other");
assert_eq!(first_value, None);
Replace any header that matches the name of header.name with header.
If there is no such header in self, add header. If the matching
header had multiple values, all of the values are removed, and only the
value in header will remain.
Replace a header that doesn't yet exist:
use rocket::http::{HeaderMap, ContentType};
let mut map = HeaderMap::new();
map.replace(ContentType::JSON);
assert!(map.get_one("Content-Type").is_some());
Replace a header that already exists:
use rocket::http::{HeaderMap, ContentType};
let mut map = HeaderMap::new();
map.replace(ContentType::JSON);
assert_eq!(map.get_one("Content-Type"), Some("application/json"));
map.replace(ContentType::GIF);
assert_eq!(map.get_one("Content-Type"), Some("image/gif"));
assert_eq!(map.len(), 1);
An example of case-insensitivity.
use rocket::http::{HeaderMap, Header, ContentType};
let mut map = HeaderMap::new();
map.replace(ContentType::JSON);
assert_eq!(map.get_one("Content-Type"), Some("application/json"));
map.replace(Header::new("CONTENT-type", "image/gif"));
assert_eq!(map.get_one("Content-Type"), Some("image/gif"));
assert_eq!(map.len(), 1);
A convenience method to replace a header using a raw name and value.
Aliases replace(Header::new(name, value)). Should be used rarely.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.replace_raw("X-Custom", "value_1");
assert_eq!(map.get_one("X-Custom"), Some("value_1"));
map.replace_raw("X-Custom", "value_2");
assert_eq!(map.get_one("X-Custom"), Some("value_2"));
assert_eq!(map.len(), 1);
Replaces all of the values for a header with name name with values.
This a low-level method and should rarely be used.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
map.add_raw("X-Custom", "value_2");
let vals: Vec<_> = map.get("X-Custom").map(|s| s.to_string()).collect();
assert_eq!(vals, vec!["value_1", "value_2"]);
map.replace_all("X-Custom", vec!["value_3".into(), "value_4".into()]);
let vals: Vec<_> = map.get("X-Custom").collect();
assert_eq!(vals, vec!["value_3", "value_4"]);
Adds header into the map. If a header with header.name was
previously added, that header will have one more value.
use rocket::http::{Cookie, HeaderMap};
let mut map = HeaderMap::new();
map.add(&Cookie::new("a", "b"));
assert_eq!(map.get("Set-Cookie").count(), 1);
map.add(&Cookie::new("c", "d"));
assert_eq!(map.get("Set-Cookie").count(), 2);
A convenience method to add a header using a raw name and value.
Aliases add(Header::new(name, value)). Should be used rarely.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
assert_eq!(map.get("X-Custom").count(), 1);
map.add_raw("X-Custom", "value_2");
let values: Vec<_> = map.get("X-Custom").collect();
assert_eq!(values, vec!["value_1", "value_2"]);
Adds all of the values to a header with name name. This a low-level
method and should rarely be used. values will be empty when this
method returns.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
let mut values = vec!["value_1".into(), "value_2".into()];
map.add_all("X-Custom", &mut values);
assert_eq!(map.get("X-Custom").count(), 2);
assert_eq!(values.len(), 0);
let mut values = vec!["value_3".into(), "value_4".into()];
map.add_all("X-Custom", &mut values);
assert_eq!(map.get("X-Custom").count(), 4);
assert_eq!(values.len(), 0);
let values: Vec<_> = map.get("X-Custom").collect();
assert_eq!(values, vec!["value_1", "value_2", "value_3", "value_4"]);
Remove all of the values for header with name name.
use rocket::http::HeaderMap;
let mut map = HeaderMap::new();
map.add_raw("X-Custom", "value_1");
map.add_raw("X-Custom", "value_2");
map.add_raw("X-Other", "other");
assert_eq!(map.len(), 3);
map.remove("X-Custom");
assert_eq!(map.len(), 1);
Removes all of the headers stored in this map and returns a vector
containing them. Header names are returned in no specific order, but all
values for a given header name are grouped together, and values are in
FIFO order.
use rocket::http::{HeaderMap, Header};
use std::collections::HashSet;
let all_headers = vec![
Header::new("X-Custom", "value_1"),
Header::new("X-Custom", "value_2"),
Header::new("X-Other", "other")
];
let mut map = HeaderMap::new();
for header in all_headers.clone() {
map.add(header)
}
assert_eq!(map.len(), 3);
let removed_headers = map.remove_all();
assert!(map.is_empty());
let expected_set: HashSet<_> = all_headers.into_iter().collect();
let actual_set: HashSet<_> = removed_headers.into_iter().collect();
assert_eq!(expected_set, actual_set);
Returns an iterator over all of the Headers stored in the map. Header
names are returned in no specific order, but all values for a given
header name are grouped together, and values are in FIFO order.
use rocket::http::{HeaderMap, Header};
let all_headers = vec![
Header::new("X-Custom", "value_1"),
Header::new("X-Other", "other"),
Header::new("X-Third", "third"),
];
let mut map = HeaderMap::new();
for header in all_headers {
map.add(header)
}
assert_eq!(map.iter().count(), 3);
for header in map.iter() {
match header.name() {
"X-Custom" => assert_eq!(header.value(), "value_1"),
"X-Other" => assert_eq!(header.value(), "other"),
"X-Third" => assert_eq!(header.value(), "third"),
_ => unreachable!("there are only three headers")
}
}
Consumes self and returns an iterator over all of the Headers stored
in the map. Header names are returned in no specific order, but all
values for a given header name are grouped together, and values are in
FIFO order.
use rocket::http::{HeaderMap, Header};
let all_headers = vec![
Header::new("X-Custom", "value_1"),
Header::new("X-Other", "other"),
Header::new("X-Third", "third"),
];
let mut map = HeaderMap::new();
for header in all_headers {
map.add(header)
}
assert_eq!(map.iter().count(), 3);
for header in map.into_iter() {
match header.name() {
"X-Custom" => assert_eq!(header.value(), "value_1"),
"X-Other" => assert_eq!(header.value(), "other"),
"X-Third" => assert_eq!(header.value(), "third"),
_ => unreachable!("there are only three headers")
}
}
This method tests for self and other values to be equal, and is used by ==. Read more
This method tests for !=.
Returns the "default value" for a type. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
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
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
🔬 This is a nightly-only experimental API. (get_type_id)
this method will likely be replaced by an associated static
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)
Mutably borrows from an owned value. Read more
Get the TypeId of this object.