pub struct Multipart { /* private fields */ }This is supported on crate feature
multipart only.Expand description
Extractor that parses multipart/form-data requests commonly used with file uploads.
Example
use axum::{
extract::Multipart,
routing::post,
Router,
};
use futures::stream::StreamExt;
async fn upload(mut multipart: Multipart) {
while let Some(mut field) = multipart.next_field().await.unwrap() {
let name = field.name().unwrap().to_string();
let data = field.bytes().await.unwrap();
println!("Length of `{}` is {} bytes", name, data.len());
}
}
let app = Router::new().route("/upload", post(upload));For security reasons its recommended to combine this with
ContentLengthLimit to limit the size of the request payload.
Implementations
Yields the next Field if available.
Trait Implementations
type Rejection = MultipartRejection
type Rejection = MultipartRejection
If the extractor fails it’ll use this “rejection” type. A rejection is a kind of error that can be converted into a response. Read more
fn from_request<'life0, 'async_trait>(
req: &'life0 mut RequestParts<B>
) -> Pin<Box<dyn Future<Output = Result<Self, Self::Rejection>> + Send + 'async_trait>> where
'life0: 'async_trait,
Self: 'async_trait,
fn from_request<'life0, 'async_trait>(
req: &'life0 mut RequestParts<B>
) -> Pin<Box<dyn Future<Output = Result<Self, Self::Rejection>> + Send + 'async_trait>> where
'life0: 'async_trait,
Self: 'async_trait,
Perform the extraction.
Auto Trait Implementations
impl !RefUnwindSafe for Multipart
impl !UnwindSafe for Multipart
Blanket Implementations
Mutably borrows from an owned value. Read more
Create a new Policy that returns Action::Follow only if self and other return
Action::Follow. Read more
pub fn vzip(self) -> V
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