Sfoglia il codice sorgente

获取请求token方法移至权限工具类

RuoYi 5 anni fa
parent
commit
91a2f7b16b

+ 5 - 0
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/constant/CacheConstants.java

@@ -31,4 +31,9 @@ public class CacheConstants
31 31
      * 用户名字段
32 32
      */
33 33
     public static final String DETAILS_USERNAME = "username";
34
+
35
+    /**
36
+     * 授权信息字段
37
+     */
38
+    public static final String AUTHORIZATION_HEADER = "authorization";
34 39
 }

+ 22 - 0
ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/utils/SecurityUtils.java

@@ -1,5 +1,6 @@
1 1
 package com.ruoyi.common.core.utils;
2 2
 
3
+import javax.servlet.http.HttpServletRequest;
3 4
 import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
4 5
 import com.ruoyi.common.core.constant.CacheConstants;
5 6
 import com.ruoyi.common.core.text.Convert;
@@ -28,6 +29,27 @@ public class SecurityUtils
28 29
     }
29 30
 
30 31
     /**
32
+     * 获取请求token
33
+     */
34
+    public static String getToken()
35
+    {
36
+        return getToken(ServletUtils.getRequest());
37
+    }
38
+
39
+    /**
40
+     * 根据request获取请求token
41
+     */
42
+    public static String getToken(HttpServletRequest request)
43
+    {
44
+        String token = ServletUtils.getRequest().getHeader(CacheConstants.HEADER);
45
+        if (StringUtils.isNotEmpty(token) && token.startsWith(CacheConstants.TOKEN_PREFIX))
46
+        {
47
+            token = token.replace(CacheConstants.TOKEN_PREFIX, "");
48
+        }
49
+        return token;
50
+    }
51
+
52
+    /**
31 53
      * 是否为管理员
32 54
      * 
33 55
      * @param userId 用户ID

+ 5 - 0
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/feign/FeignRequestInterceptor.java

@@ -35,6 +35,11 @@ public class FeignRequestInterceptor implements RequestInterceptor
35 35
             {
36 36
                 requestTemplate.header(CacheConstants.DETAILS_USERNAME, userName);
37 37
             }
38
+            String authentication = headers.get(CacheConstants.AUTHORIZATION_HEADER);
39
+            if (StringUtils.isNotEmpty(authentication))
40
+            {
41
+                requestTemplate.header(CacheConstants.AUTHORIZATION_HEADER, authentication);
42
+            }
38 43
         }
39 44
     }
40 45
 }

+ 2 - 14
ruoyi-common/ruoyi-common-security/src/main/java/com/ruoyi/common/security/service/TokenService.java

@@ -9,6 +9,7 @@ import org.springframework.stereotype.Component;
9 9
 import com.ruoyi.common.core.constant.CacheConstants;
10 10
 import com.ruoyi.common.core.constant.Constants;
11 11
 import com.ruoyi.common.core.utils.IdUtils;
12
+import com.ruoyi.common.core.utils.SecurityUtils;
12 13
 import com.ruoyi.common.core.utils.ServletUtils;
13 14
 import com.ruoyi.common.core.utils.StringUtils;
14 15
 import com.ruoyi.common.core.utils.ip.IpUtils;
@@ -71,7 +72,7 @@ public class TokenService
71 72
     public LoginUser getLoginUser(HttpServletRequest request)
72 73
     {
73 74
         // 获取请求携带的令牌
74
-        String token = getToken(request);
75
+        String token = SecurityUtils.getToken(request);
75 76
         if (StringUtils.isNotEmpty(token))
76 77
         {
77 78
             String userKey = getTokenKey(token);
@@ -119,17 +120,4 @@ public class TokenService
119 120
     {
120 121
         return ACCESS_TOKEN + token;
121 122
     }
122
-
123
-    /**
124
-     * 获取请求token
125
-     */
126
-    private String getToken(HttpServletRequest request)
127
-    {
128
-        String token = request.getHeader(CacheConstants.HEADER);
129
-        if (StringUtils.isNotEmpty(token) && token.startsWith(CacheConstants.TOKEN_PREFIX))
130
-        {
131
-            token = token.replace(CacheConstants.TOKEN_PREFIX, "");
132
-        }
133
-        return token;
134
-    }
135 123
 }