Module tower_http::cors
source · [−]This is supported on crate feature
cors only.Expand description
Middleware which adds headers for CORS.
Example
use http::{Request, Response, Method, header};
use hyper::Body;
use tower::{ServiceBuilder, ServiceExt, Service};
use tower_http::cors::{CorsLayer, any};
use std::convert::Infallible;
async fn handle(request: Request<Body>) -> Result<Response<Body>, Infallible> {
Ok(Response::new(Body::empty()))
}
let cors = CorsLayer::new()
// allow `GET` and `POST` when accessing the resource
.allow_methods(vec![Method::GET, Method::POST])
// allow requests from any origin
.allow_origin(any());
let mut service = ServiceBuilder::new()
.layer(cors)
.service_fn(handle);
let request = Request::builder()
.header(header::ORIGIN, "https://example.com")
.body(Body::empty())
.unwrap();
let response = service
.ready()
.await?
.call(request)
.await?;
assert_eq!(
response.headers().get(header::ACCESS_CONTROL_ALLOW_ORIGIN).unwrap(),
"*",
);Structs
Represents a wildcard value (*) used with some CORS headers such as
CorsLayer::allow_methods.
Used to make methods like CorsLayer::allow_methods more convenient to call.
Represents a Access-Control-Allow-Origin header.
Response future for Cors.
Functions
Represents a wildcard value (*) used with some CORS headers such as
CorsLayer::allow_methods.