Middleware de Journalisation

La journalisation joue un rôle essentiel dans les applications web, car elle permet :

  • De fournir des informations détaillées sur le processus de traitement des requêtes pour aider les développeurs à suivre le comportement de l'application
  • D'assister dans le dépannage et le débogage, particulièrement dans les environnements de production
  • De surveiller les performances de l'application et l'utilisation des ressources
  • D'enregistrer les modèles d'accès des utilisateurs et les exceptions système
  • De répondre aux exigences d'audit de sécurité et de conformité

Salvo fournit un middleware avec des fonctionnalités de journalisation de base. Si le middleware est ajouté directement à un Router, il ne capturera pas les erreurs 404 renvoyées lorsqu'aucun Router ne correspond à la requête. Il est recommandé de l'ajouter plutôt au Service.

Exemple de Code

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;
}