From fb387614d499f86418098a14dc62f19f8ef2937d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9D=8E=E8=BF=90=E5=AE=B6?= Date: Thu, 30 May 2024 17:50:33 +0800 Subject: [PATCH] =?UTF-8?q?token=E6=A0=A1=E9=AA=8C=E5=A2=9E=E5=8A=A0?= =?UTF-8?q?=E7=99=BD=E5=90=8D=E5=8D=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/src/router.rs | 5 +++-- library/src/middleware/req_token.rs | 14 ++++++++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/api/src/router.rs b/api/src/router.rs index 74de224..27b5249 100644 --- a/api/src/router.rs +++ b/api/src/router.rs @@ -8,9 +8,10 @@ use tower_http::trace::TraceLayer; pub(crate) fn init() -> Router { let open = Router::new().route("/", get(|| async { "hello" })); - let auth = Router::new() + let auth: Router = Router::new() .route("/account/google", post(controller::account::authenticate_google)) - .route("/feedback", post(controller::feedback::add_feedback).get(controller::feedback::get_feedback_list_by_page)); + .route("/feedback", post(controller::feedback::add_feedback).get(controller::feedback::get_feedback_list_by_page)) + .layer(axum::middleware::from_fn(library::middleware::req_token::authenticate_access_token)); Router::new() .nest("/", open) diff --git a/library/src/middleware/req_token.rs b/library/src/middleware/req_token.rs index 9bcbc50..ea6f770 100644 --- a/library/src/middleware/req_token.rs +++ b/library/src/middleware/req_token.rs @@ -4,8 +4,22 @@ use jsonwebtoken::{decode, DecodingKey, Validation}; use crate::{cache::login_cache::LOGIN_CACHE, config, token::Claims}; +const WHITE_LIST: &[(&str, &str)] = &[ + ("GET", "/api/v1/users/:id"), + ("POST", "/api/v1/orders"), + ("GET", "/feedback") +]; pub async fn authenticate_access_token(mut req: Request, next: Next) -> Response { + // 获取请求的url和method,然后判断是否在白名单中,如果在白名单中,则直接返回next(req),否则继续执行下面的代码 + let method = req.method().clone().to_string(); + let uri = req.uri().path_and_query().unwrap().to_string(); + if WHITE_LIST.into_iter().find(|item| { + return item.0 == method && item.1 == uri; + }).is_some() { + return next.run(req).await; + } + let auth_header = req.headers().get(header::AUTHORIZATION); let token = match auth_header { Some(header_value) => {