pub struct NormalizePath(/* private fields */);Expand description
Middleware for normalizing a request’s path so that routes can be matched more flexibly.
§Normalization Steps
- Merges consecutive slashes into one. (For example, /path//onealways becomes/path/one.)
- Appends a trailing slash if one is not present, removes one if present, or keeps trailing
slashes as-is, depending on which TrailingSlashvariant is supplied tonew.
§Default Behavior
The default constructor chooses to strip trailing slashes from the end of paths with them
(TrailingSlash::Trim). The implication is that route definitions should be defined without
trailing slashes or else they will be inaccessible (or vice versa when using the
TrailingSlash::Always behavior), as shown in the example tests below.
§Examples
use actix_web::{web, middleware, App};
let app = App::new()
    .wrap(middleware::NormalizePath::trim())
    .route("/test", web::get().to(|| async { "test" }))
    .route("/unmatchable/", web::get().to(|| async { "unmatchable" }));
use actix_web::http::StatusCode;
use actix_web::test::{call_service, init_service, TestRequest};
let app = init_service(app).await;
let req = TestRequest::with_uri("/test").to_request();
let res = call_service(&app, req).await;
assert_eq!(res.status(), StatusCode::OK);
let req = TestRequest::with_uri("/test/").to_request();
let res = call_service(&app, req).await;
assert_eq!(res.status(), StatusCode::OK);
let req = TestRequest::with_uri("/unmatchable").to_request();
let res = call_service(&app, req).await;
assert_eq!(res.status(), StatusCode::NOT_FOUND);
let req = TestRequest::with_uri("/unmatchable/").to_request();
let res = call_service(&app, req).await;
assert_eq!(res.status(), StatusCode::NOT_FOUND);Implementations§
Source§impl NormalizePath
 
impl NormalizePath
Sourcepub fn new(trailing_slash_style: TrailingSlash) -> Self
 
pub fn new(trailing_slash_style: TrailingSlash) -> Self
Create new NormalizePath middleware with the specified trailing slash style.
Trait Implementations§
Source§impl Clone for NormalizePath
 
impl Clone for NormalizePath
Source§fn clone(&self) -> NormalizePath
 
fn clone(&self) -> NormalizePath
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from 
source. Read moreSource§impl Debug for NormalizePath
 
impl Debug for NormalizePath
Source§impl Default for NormalizePath
 
impl Default for NormalizePath
Source§impl<S, B> Transform<S, ServiceRequest> for NormalizePath
 
impl<S, B> Transform<S, ServiceRequest> for NormalizePath
Source§type Response = ServiceResponse<B>
 
type Response = ServiceResponse<B>
Responses produced by the service.
Source§type Transform = NormalizePathNormalization<S>
 
type Transform = NormalizePathNormalization<S>
The 
TransformService value created by this factorySource§type Future = Ready<Result<<NormalizePath as Transform<S, ServiceRequest>>::Transform, <NormalizePath as Transform<S, ServiceRequest>>::InitError>>
 
type Future = Ready<Result<<NormalizePath as Transform<S, ServiceRequest>>::Transform, <NormalizePath as Transform<S, ServiceRequest>>::InitError>>
The future response value.
Source§fn new_transform(&self, service: S) -> Self::Future
 
fn new_transform(&self, service: S) -> Self::Future
Creates and returns a new Transform component, asynchronously
impl Copy for NormalizePath
Auto Trait Implementations§
impl Freeze for NormalizePath
impl RefUnwindSafe for NormalizePath
impl Send for NormalizePath
impl Sync for NormalizePath
impl Unpin for NormalizePath
impl UnwindSafe for NormalizePath
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more