Middleware de Registro

O registro desempenha um papel crucial em aplicações web, pois permite:

  • Fornecer informações detalhadas sobre o processo de manipulação de solicitações para ajudar os desenvolvedores a rastrear o comportamento do aplicativo
  • Auxiliar na solução de problemas e depuração, especialmente em ambientes de produção
  • Monitorar o desempenho do aplicativo e o uso de recursos
  • Registrar padrões de acesso do usuário e exceções do sistema
  • Atender aos requisitos de auditoria de segurança e conformidade

O Salvo fornece um middleware com funcionalidade básica de registro. Se o middleware for adicionado diretamente a um Router, ele não capturará erros 404 retornados quando nenhum Router corresponder à solicitação. Recomenda-se adicioná-lo ao Service em vez disso.

Código de Exemplo

main.rs
Cargo.toml
use salvo::logging::Logger;
use salvo::prelude::*;

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

#[handler]
async fn error() -> StatusError {
    StatusError::bad_request()
        .brief("Bad request error")
        .detail("The request was malformed.")
}

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

    let router = Router::new()
        .get(hello)
        .push(Router::with_path("error").get(error));
    let service = Service::new(router).hoop(Logger::new());

    let acceptor = TcpListener::new("0.0.0.0:8698").bind().await;
    Server::new(acceptor).serve(service).await;
}