Request

Struct Request 

Source
#[non_exhaustive]
pub struct Request<'conn> { pub method: Method, pub authority: String, pub path: String, pub raw_query: String, pub body: Box<dyn Read + 'conn>, pub headers: Headers, pub path_values: BTreeMap<String, String>, pub cookies: Vec<(String, String)>, pub ip: SocketAddr, pub shutdown: Signal, }
Expand description

An incoming http request

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§method: Method

The request method

§authority: String

The authority portion of the url

§path: String

The url path

§raw_query: String

The query string

Use Request::parse_query to parse it

§body: Box<dyn Read + 'conn>

The request body

§headers: Headers

The request headers

§path_values: BTreeMap<String, String>

The values of the matched path patterns from PathRouter.

Can also be used to store arbitrary values for downstream http handlers

§cookies: Vec<(String, String)>

Cookie pairs present on this request.

§ip: SocketAddr

The address of the HTTP client

§shutdown: Signal

A signal that the server is shutting down.

Request handlers that perform long running tasks should periodically use this to check if a server is requesting a shutdown.

Implementations§

Source§

impl Request<'_>

Source

pub fn parse_query(&self) -> UrlEncodedParams

Returns the parsed query string

Source

pub fn parse_form_body(&mut self) -> Result<UrlEncodedParams>

Attempts to parse the body as application/x-www-form-urlencoded

This function consumes the body stream.

Auto Trait Implementations§

§

impl<'conn> Freeze for Request<'conn>

§

impl<'conn> !RefUnwindSafe for Request<'conn>

§

impl<'conn> !Send for Request<'conn>

§

impl<'conn> !Sync for Request<'conn>

§

impl<'conn> Unpin for Request<'conn>

§

impl<'conn> !UnwindSafe for Request<'conn>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.