Просмотр исходного кода

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

RuoYi лет назад: 5
Родитель
Сommit
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
     public static final String DETAILS_USERNAME = "username";
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
 package com.ruoyi.common.core.utils;
1
 package com.ruoyi.common.core.utils;
2
 
2
 
3
+import javax.servlet.http.HttpServletRequest;
3
 import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
4
 import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
4
 import com.ruoyi.common.core.constant.CacheConstants;
5
 import com.ruoyi.common.core.constant.CacheConstants;
5
 import com.ruoyi.common.core.text.Convert;
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
      * @param userId 用户ID
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
                 requestTemplate.header(CacheConstants.DETAILS_USERNAME, userName);
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
 import com.ruoyi.common.core.constant.CacheConstants;
9
 import com.ruoyi.common.core.constant.CacheConstants;
10
 import com.ruoyi.common.core.constant.Constants;
10
 import com.ruoyi.common.core.constant.Constants;
11
 import com.ruoyi.common.core.utils.IdUtils;
11
 import com.ruoyi.common.core.utils.IdUtils;
12
+import com.ruoyi.common.core.utils.SecurityUtils;
12
 import com.ruoyi.common.core.utils.ServletUtils;
13
 import com.ruoyi.common.core.utils.ServletUtils;
13
 import com.ruoyi.common.core.utils.StringUtils;
14
 import com.ruoyi.common.core.utils.StringUtils;
14
 import com.ruoyi.common.core.utils.ip.IpUtils;
15
 import com.ruoyi.common.core.utils.ip.IpUtils;
@@ -71,7 +72,7 @@ public class TokenService
71
     public LoginUser getLoginUser(HttpServletRequest request)
72
     public LoginUser getLoginUser(HttpServletRequest request)
72
     {
73
     {
73
         // 获取请求携带的令牌
74
         // 获取请求携带的令牌
74
-        String token = getToken(request);
75
+        String token = SecurityUtils.getToken(request);
75
         if (StringUtils.isNotEmpty(token))
76
         if (StringUtils.isNotEmpty(token))
76
         {
77
         {
77
             String userKey = getTokenKey(token);
78
             String userKey = getTokenKey(token);
@@ -119,17 +120,4 @@ public class TokenService
119
     {
120
     {
120
         return ACCESS_TOKEN + token;
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
 }