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 |   42 ++++++++++++++++++++++++++++++++++++++----
 1 files changed, 38 insertions(+), 4 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 f4e2b5f..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
@@ -1,7 +1,15 @@
 package com.ruoyi.framework.config;
 
+import cn.dev33.satoken.interceptor.SaAnnotationInterceptor;
+import cn.dev33.satoken.interceptor.SaRouteInterceptor;
+import cn.dev33.satoken.router.SaRouter;
+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;
@@ -11,6 +19,9 @@
 import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
 import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
 
+import java.util.Arrays;
+import java.util.Collections;
+
 /**
  * 閫氱敤閰嶇疆
  *
@@ -19,16 +30,39 @@
 @Configuration
 public class ResourcesConfig implements WebMvcConfigurer {
 
-    @Override
-    public void addResourceHandlers(ResourceHandlerRegistry registry) {
-    }
+    @Autowired
+    private SecurityProperties securityProperties;
 
+    // 娉ㄥ唽sa-token鐨勬嫤鎴櫒
     @Override
     public void addInterceptors(InterceptorRegistry registry) {
         // 鍏ㄥ眬閾捐矾璺熻釜鎷︽埅鍣�
         registry.addInterceptor(new TLogWebInterceptor());
         // 鍏ㄥ眬璁块棶鎬ц兘鎷︽埅
         registry.addInterceptor(new PlusWebInvokeTimeInterceptor());
+        // 娉ㄥ唽璺敱鎷︽埅鍣紝鑷畾涔夐獙璇佽鍒�
+        registry.addInterceptor(new SaRouteInterceptor((request, response, handler) -> {
+            // 鐧诲綍楠岃瘉 -- 鎺掗櫎澶氫釜璺緞
+            SaRouter
+                    // 鑾峰彇鎵�鏈夌殑
+                    .match(Collections.singletonList("/**"))
+                    // 鎺掗櫎涓嬩笉闇�瑕佹嫤鎴殑
+                    .notMatch(Arrays.asList(securityProperties.getExcludes()))
+                    .check(() -> {
+                        Long userId = SecurityUtils.getUserId();
+                        if(StringUtils.isNotNull(userId) ) {
+                            long tokenTimeout = StpUtil.getTokenTimeout();
+                            long tokenActivityTimeout = StpUtil.getTokenActivityTimeout();
+                            System.out.println("鍓╀綑鏈夋晥鏃堕棿: " + tokenTimeout);
+                            System.out.println("涓存椂鏈夋晥鏃堕棿: " + tokenActivityTimeout);
+                        }
+                    });
+        })).addPathPatterns("/**");
+        registry.addInterceptor(new SaAnnotationInterceptor()).addPathPatterns("/**");
+    }
+
+    @Override
+    public void addResourceHandlers(ResourceHandlerRegistry registry) {
     }
 
     /**
@@ -52,4 +86,4 @@
         // 杩斿洖鏂扮殑CorsFilter
         return new CorsFilter(source);
     }
-}
\ No newline at end of file
+}

--
Gitblit v1.9.3