2024-01-10 04:00:20 +00:00
# `actix-multipart`
2019-04-29 20:47:21 -07:00
2024-01-10 04:00:20 +00:00
<!-- prettier - ignore - start -->
2021-02-10 12:10:03 +00:00
[data:image/s3,"s3://crabby-images/ecafc/ecafc76b6d1c9cae14aaa3ecf903af381dcb325d" alt="crates.io "](https://crates.io/crates/actix-multipart)
2024-07-07 00:34:18 +01:00
[data:image/s3,"s3://crabby-images/02a9a/02a9aaac9753bc0471033aefbf91bd68f820cc83" alt="Documentation "](https://docs.rs/actix-multipart/0.7.2)
2024-02-13 01:24:34 +00:00
data:image/s3,"s3://crabby-images/34d65/34d655b15218e22586e7d84b1f7ee87b09907726" alt="Version "
2021-02-10 12:10:03 +00:00
data:image/s3,"s3://crabby-images/60e3c/60e3c3d18ef68e373e6716abc602f15d334fd960" alt="MIT or Apache 2.0 licensed "
< br / >
2024-07-07 00:34:18 +01:00
[data:image/s3,"s3://crabby-images/8065f/8065ff4ec3c39e11a56abcee2b41dfa1f22cdf62" alt="dependency status "](https://deps.rs/crate/actix-multipart/0.7.2)
2021-02-10 12:10:03 +00:00
[data:image/s3,"s3://crabby-images/bfa0e/bfa0e01f202b72922e1f231a85cf725bc9978c35" alt="Download "](https://crates.io/crates/actix-multipart)
2021-06-26 16:33:36 +01:00
[data:image/s3,"s3://crabby-images/d3471/d347105c7af89cd73879ec388f87dee9608385c3" alt="Chat on Discord "](https://discord.gg/NWpN5mmg3x)
2021-02-10 12:10:03 +00:00
2024-01-10 04:00:20 +00:00
<!-- prettier - ignore - end -->
2024-05-18 21:02:00 +02:00
2024-06-10 23:35:26 +01:00
<!-- cargo - rdme start -->
2024-05-18 21:02:00 +02:00
2024-07-07 20:32:56 +01:00
Multipart request & form support for Actix Web.
The [`Multipart` ] extractor aims to support all kinds of `multipart/*` requests, including `multipart/form-data` , `multipart/related` and `multipart/mixed` . This is a lower-level extractor which supports reading [multipart fields ](Field ), in the order they are sent by the client.
Due to additional requirements for `multipart/form-data` requests, the higher level [`MultipartForm` ] extractor and derive macro only supports this media type.
2024-05-18 21:02:00 +02:00
2024-06-10 23:35:26 +01:00
## Examples
2024-05-18 21:02:00 +02:00
```rust
use actix_web::{post, App, HttpServer, Responder};
2024-07-07 20:32:56 +01:00
use actix_multipart::form::{json::Json as MpJson, tempfile::TempFile, MultipartForm};
2024-05-18 21:02:00 +02:00
use serde::Deserialize;
#[derive(Debug, Deserialize)]
struct Metadata {
name: String,
}
#[derive(Debug, MultipartForm)]
struct UploadForm {
#[multipart(limit = "100MB")]
file: TempFile,
2024-07-07 20:32:56 +01:00
json: MpJson< Metadata > ,
2024-05-18 21:02:00 +02:00
}
#[post("/videos")]
pub async fn post_video(MultipartForm(form): MultipartForm< UploadForm > ) -> impl Responder {
format!(
"Uploaded file {}, with size: {}",
form.json.name, form.file.size
)
}
#[actix_web::main]
async fn main() -> std::io::Result< ()> {
HttpServer::new(move || App::new().service(post_video))
.bind(("127.0.0.1", 8080))?
.run()
.await
}
```
2024-07-01 03:55:08 +01:00
cURL request:
2024-06-07 16:04:04 +01:00
2024-07-01 03:55:08 +01:00
```sh
2024-05-18 21:02:00 +02:00
curl -v --request POST \
--url http://localhost:8080/videos \
-F 'json={"name": "Cargo.lock"};type=application/json' \
-F file=@./Cargo.lock
```
2024-07-01 03:55:08 +01:00
2024-07-07 20:32:56 +01:00
[`MultipartForm` ]: struct@form::MultipartForm
2024-07-01 03:55:08 +01:00
<!-- cargo - rdme end -->
[More available in the examples repo → ](https://github.com/actix/examples/tree/master/forms/multipart )