|
|
@@ -24,6 +24,8 @@ import com.ruoyi.common.core.utils.StringUtils;
|
|
24
|
24
|
import com.ruoyi.common.redis.service.RedisService;
|
|
25
|
25
|
import com.ruoyi.gateway.config.properties.IgnoreWhiteProperties;
|
|
26
|
26
|
import reactor.core.publisher.Mono;
|
|
|
27
|
+import java.io.UnsupportedEncodingException;
|
|
|
28
|
+import java.net.URLEncoder;
|
|
27
|
29
|
|
|
28
|
30
|
/**
|
|
29
|
31
|
* 网关鉴权
|
|
|
@@ -68,7 +70,7 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
68
|
70
|
}
|
|
69
|
71
|
JSONObject obj = JSONObject.parseObject(userStr);
|
|
70
|
72
|
String userid = obj.getString("userid");
|
|
71
|
|
- String username = obj.getString("username");
|
|
|
73
|
+ String username = urlEncode(obj.getString("username"));
|
|
72
|
74
|
if (StringUtils.isBlank(userid) || StringUtils.isBlank(username))
|
|
73
|
75
|
{
|
|
74
|
76
|
return setUnauthorizedResponse(exchange, "令牌验证失败");
|
|
|
@@ -104,6 +106,18 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
104
|
106
|
}
|
|
105
|
107
|
|
|
106
|
108
|
/**
|
|
|
109
|
+ * 编码
|
|
|
110
|
+ */
|
|
|
111
|
+ private String urlEncode(String value) {
|
|
|
112
|
+ try {
|
|
|
113
|
+ value = URLEncoder.encode(value, "UTF-8");
|
|
|
114
|
+ } catch (UnsupportedEncodingException e) {
|
|
|
115
|
+ e.printStackTrace();
|
|
|
116
|
+ }
|
|
|
117
|
+ return value;
|
|
|
118
|
+ }
|
|
|
119
|
+
|
|
|
120
|
+ /**
|
|
107
|
121
|
* 获取请求token
|
|
108
|
122
|
*/
|
|
109
|
123
|
private String getToken(ServerHttpRequest request)
|