//! Run with //! //! ```not_rust //! cargo run --example 404 //! ``` use axum::{ body::{box_body, Body, BoxBody}, prelude::*, }; use http::{Response, StatusCode}; use std::net::SocketAddr; use tower::util::MapResponseLayer; #[tokio::main] async fn main() { // Set the RUST_LOG, if it hasn't been explicitly defined if std::env::var("RUST_LOG").is_err() { std::env::set_var("RUST_LOG", "404=debug") } tracing_subscriber::fmt::init(); // build our application with a route let app = route("/", get(handler)) // make sure this is added as the very last thing .layer(MapResponseLayer::new(map_404)); // run it let addr = SocketAddr::from(([127, 0, 0, 1], 3000)); tracing::debug!("listening on {}", addr); axum::Server::bind(&addr) .serve(app.into_make_service()) .await .unwrap(); } async fn handler() -> response::Html<&'static str> { response::Html("