mirror of
https://github.com/tokio-rs/axum.git
synced 2025-09-28 21:40:55 +00:00
Update static file server example (#1011)
This commit is contained in:
parent
852e548e19
commit
7774cfd1f7
@ -6,6 +6,7 @@ publish = false
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
axum = { path = "../../axum" }
|
axum = { path = "../../axum" }
|
||||||
|
axum-extra = { path = "../../axum-extra", features = ["spa"] }
|
||||||
tokio = { version = "1.0", features = ["full"] }
|
tokio = { version = "1.0", features = ["full"] }
|
||||||
tracing = "0.1"
|
tracing = "0.1"
|
||||||
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
|
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
|
||||||
|
@ -4,8 +4,13 @@
|
|||||||
//! cd examples && cargo run -p example-static-file-server
|
//! cd examples && cargo run -p example-static-file-server
|
||||||
//! ```
|
//! ```
|
||||||
|
|
||||||
use axum::{http::StatusCode, routing::get_service, Router};
|
use axum::{
|
||||||
use std::net::SocketAddr;
|
http::StatusCode,
|
||||||
|
response::IntoResponse,
|
||||||
|
routing::{get, get_service},
|
||||||
|
Router,
|
||||||
|
};
|
||||||
|
use std::{io, net::SocketAddr};
|
||||||
use tower_http::{services::ServeDir, trace::TraceLayer};
|
use tower_http::{services::ServeDir, trace::TraceLayer};
|
||||||
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
|
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
|
||||||
|
|
||||||
@ -19,16 +24,17 @@ async fn main() {
|
|||||||
.with(tracing_subscriber::fmt::layer())
|
.with(tracing_subscriber::fmt::layer())
|
||||||
.init();
|
.init();
|
||||||
|
|
||||||
let app = Router::new()
|
// `SpaRouter` is the easiest way to serve assets at a nested route like `/assets`
|
||||||
.nest(
|
// let app = Router::new()
|
||||||
"/static",
|
// .route("/foo", get(|| async { "Hi from /foo" }))
|
||||||
get_service(ServeDir::new(".")).handle_error(|error: std::io::Error| async move {
|
// .merge(axum_extra::routing::SpaRouter::new("/assets", "."))
|
||||||
(
|
// .layer(TraceLayer::new_for_http());
|
||||||
StatusCode::INTERNAL_SERVER_ERROR,
|
|
||||||
format!("Unhandled internal error: {}", error),
|
// for serving assets directly at the root you can use `tower_http::services::ServeDir`
|
||||||
)
|
// as the fallback to a `Router`
|
||||||
}),
|
let app: _ = Router::new()
|
||||||
)
|
.route("/foo", get(|| async { "Hi from /foo" }))
|
||||||
|
.fallback(get_service(ServeDir::new(".")).handle_error(handle_error))
|
||||||
.layer(TraceLayer::new_for_http());
|
.layer(TraceLayer::new_for_http());
|
||||||
|
|
||||||
let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
|
let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
|
||||||
@ -38,3 +44,7 @@ async fn main() {
|
|||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn handle_error(_err: io::Error) -> impl IntoResponse {
|
||||||
|
(StatusCode::INTERNAL_SERVER_ERROR, "Something went wrong...")
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user