HTTPS強制化

force-httpsミドルウェアは、すべてのリクエストをHTTPSプロトコルに強制的にリダイレクトします。

このミドルウェアをRouterに適用した場合、ルートが一致したときのみプロトコル変換が強制されます。ページが存在しない状況ではリダイレクトされません。

しかし、より一般的な要件は、ルートが一致せず404エラーが返される場合でも、あらゆるリクエストを自動的にリダイレクトすることです。この場合、ミドルウェアをServiceに追加します。リクエストがルートに正常に一致したかどうかに関わらず、Serviceに追加されたミドルウェアは常に実行されます。

サンプルコード

main.rs
Cargo.toml
use salvo::conn::rustls::{Keycert, RustlsConfig};
use salvo::prelude::*;

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

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

    let router = Router::new().get(hello);
    let service = Service::new(router).hoop(ForceHttps::new().https_port(5443));

    let config = RustlsConfig::new(
        Keycert::new()
            .cert(include_bytes!("../certs/cert.pem").as_ref())
            .key(include_bytes!("../certs/key.pem").as_ref()),
    );
    let acceptor = TcpListener::new("0.0.0.0:5443")
        .rustls(config)
        .join(TcpListener::new("0.0.0.0:8698"))
        .bind()
        .await;
    Server::new(acceptor).serve(service).await;
}