logo
pub struct Form<T>(pub T);
Expand description

An extractor that can deserialize some type from query string or body.

If the method is not GET, the query parameters will be parsed from the body, otherwise it is like Query.

If the Content-Type is not application/x-www-form-urlencoded, then a Bad Request response will be returned.

Errors

Example

use poem::{
    get, handler,
    http::{Method, StatusCode, Uri},
    web::Form,
    Endpoint, Request, Route,
};
use serde::Deserialize;

#[derive(Deserialize)]
struct CreateDocument {
    title: String,
    content: String,
}

#[handler]
fn index(Form(CreateDocument { title, content }): Form<CreateDocument>) -> String {
    format!("{}:{}", title, content)
}

let app = Route::new().at("/", get(index).post(index));

let resp = app
    .call(
        Request::builder()
            .uri(Uri::from_static("/?title=foo&content=bar"))
            .finish(),
    )
    .await
    .unwrap();
assert_eq!(resp.status(), StatusCode::OK);
assert_eq!(resp.into_body().into_string().await.unwrap(), "foo:bar");

let resp = app
    .call(
        Request::builder()
            .method(Method::POST)
            .uri(Uri::from_static("/"))
            .content_type("application/x-www-form-urlencoded")
            .body("title=foo&content=bar"),
    )
    .await
    .unwrap();
assert_eq!(resp.status(), StatusCode::OK);
assert_eq!(resp.into_body().into_string().await.unwrap(), "foo:bar");

Tuple Fields

0: T

Trait Implementations

The resulting type after dereferencing.

Dereferences the value.

Mutably dereferences the value.

Extract from request head and body.

Extract from request head. Read more

Auto Trait Implementations

Blanket Implementations

A guard object containing the value and keeping it alive. Read more

The loading method. Read more

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

The equivalent of [Access::load].

Performs the conversion.

Attaches the provided Context to this type, returning a WithContext wrapper. Read more

Attaches the current Context to this type, returning a WithContext wrapper. Read more

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more

Instruments this type with the current Span, returning an Instrumented wrapper. Read more

Performs the conversion.

Should always be Self

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more