From 695cb6d76b838b1e4cb161bae335faa948dca12a Mon Sep 17 00:00:00 2001
From: 疯狂的狮子li <15040126243@163.com>
Date: 星期三, 27 十月 2021 13:16:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into satoken

---
 ruoyi-framework/src/main/java/com/ruoyi/framework/config/ResourcesConfig.java |   50 ++++++++++++++++++++++----------------------------
 1 files changed, 22 insertions(+), 28 deletions(-)

diff --git a/ruoyi-framework/src/main/java/com/ruoyi/framework/config/ResourcesConfig.java b/ruoyi-framework/src/main/java/com/ruoyi/framework/config/ResourcesConfig.java
index 3b19e57..6200634 100644
--- a/ruoyi-framework/src/main/java/com/ruoyi/framework/config/ResourcesConfig.java
+++ b/ruoyi-framework/src/main/java/com/ruoyi/framework/config/ResourcesConfig.java
@@ -6,6 +6,10 @@
 import cn.dev33.satoken.stp.StpUtil;
 import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.framework.config.properties.SecurityProperties;
+import com.ruoyi.framework.Interceptor.PlusWebInvokeTimeInterceptor;
+import com.yomahub.tlog.web.interceptor.TLogWebInterceptor;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.context.annotation.Bean;
 import org.springframework.context.annotation.Configuration;
 import org.springframework.web.cors.CorsConfiguration;
@@ -17,7 +21,6 @@
 
 import java.util.Arrays;
 import java.util.Collections;
-import java.util.List;
 
 /**
  * 閫氱敤閰嶇疆
@@ -27,37 +30,25 @@
 @Configuration
 public class ResourcesConfig implements WebMvcConfigurer {
 
+    @Autowired
+    private SecurityProperties securityProperties;
+
     // 娉ㄥ唽sa-token鐨勬嫤鎴櫒
     @Override
     public void addInterceptors(InterceptorRegistry registry) {
-        List<String> urlPath = Arrays.asList(
-                "/login",
-                "/logout",
-                "/captchaImage",
-                "/*.html",
-                "/**/*.html",
-                "/**/*.css",
-                "/**/*.js",
-                "/profile/**",
-                "/common/download**",
-                "/common/download/resource**",
-                "/swagger-ui.html",
-                "/swagger-resources/**",
-                "/webjars/**",
-                "/*/api-docs",
-                "/druid/**",
-                "/actuator",
-                "/actuator/**"
-        );
+        // 鍏ㄥ眬閾捐矾璺熻釜鎷︽埅鍣�
+        registry.addInterceptor(new TLogWebInterceptor());
+        // 鍏ㄥ眬璁块棶鎬ц兘鎷︽埅
+        registry.addInterceptor(new PlusWebInvokeTimeInterceptor());
         // 娉ㄥ唽璺敱鎷︽埅鍣紝鑷畾涔夐獙璇佽鍒�
         registry.addInterceptor(new SaRouteInterceptor((request, response, handler) -> {
             // 鐧诲綍楠岃瘉 -- 鎺掗櫎澶氫釜璺緞
-            SaRouter.match(
-                    //鑾峰彇鎵�鏈夌殑
-                    Collections.singletonList("/**"),
-                    //鎺掗櫎涓嬩笉闇�瑕佹嫤鎴殑
-                    urlPath,
-                    () -> {
+            SaRouter
+                    // 鑾峰彇鎵�鏈夌殑
+                    .match(Collections.singletonList("/**"))
+                    // 鎺掗櫎涓嬩笉闇�瑕佹嫤鎴殑
+                    .notMatch(Arrays.asList(securityProperties.getExcludes()))
+                    .check(() -> {
                         Long userId = SecurityUtils.getUserId();
                         if(StringUtils.isNotNull(userId) ) {
                             long tokenTimeout = StpUtil.getTokenTimeout();
@@ -79,7 +70,6 @@
      */
     @Bean
     public CorsFilter corsFilter() {
-        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
         CorsConfiguration config = new CorsConfiguration();
         config.setAllowCredentials(true);
         // 璁剧疆璁块棶婧愬湴鍧�
@@ -88,8 +78,12 @@
         config.addAllowedHeader("*");
         // 璁剧疆璁块棶婧愯姹傛柟娉�
         config.addAllowedMethod("*");
-        // 瀵规帴鍙i厤缃法鍩熻缃�
+        // 鏈夋晥鏈� 1800绉�
+        config.setMaxAge(1800L);
+        // 娣诲姞鏄犲皠璺緞锛屾嫤鎴竴鍒囪姹�
+        UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
         source.registerCorsConfiguration("/**", config);
+        // 杩斿洖鏂扮殑CorsFilter
         return new CorsFilter(source);
     }
 }

--
Gitblit v1.9.3