Caché en Cabeceras

Es el Middleware que provee soporte a caché para la configuración de cabeceras.

En efecto, la implementación contiene tres implementaciones de Handler de CachingHeaders, Modified, ETag, y CachingHeaders es una combinación de las últimas dos. Normalmente, es usado CachingHeaders.

Ejemplo

use salvo::prelude::*;

#[handler]
async fn hello() -> &'static str {
    "Hello World"
}

#[tokio::main]
async fn main() {
    tracing_subscriber::fmt().init();

    // CachingHeader must be before Compression.
    let router = Router::with_hoop(CachingHeaders::new())
        .hoop(Compression::new().min_length(0))
        .get(hello);
    let acceptor = TcpListener::new("127.0.0.1:5800").bind().await;
    Server::new(acceptor).serve(router).await;
}
[package]
name = "example-caching-headers"
version = "0.1.0"
edition = "2021"
publish = false

[dependencies]
salvo = { workspace = true, features = ["caching-headers", "compression"] }
tokio = { version = "1", features = ["macros"] }
tracing = "0.1"
tracing-subscriber = "0.3"