|
|
@ -18,8 +18,10 @@ import org.springframework.web.server.ServerWebExchange;
|
|
|
|
import com.alibaba.fastjson.JSON;
|
|
|
|
import com.alibaba.fastjson.JSON;
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
|
import com.ruoyi.common.core.constant.CacheConstants;
|
|
|
|
import com.ruoyi.common.core.constant.CacheConstants;
|
|
|
|
|
|
|
|
import com.ruoyi.common.core.constant.Constants;
|
|
|
|
import com.ruoyi.common.core.domain.R;
|
|
|
|
import com.ruoyi.common.core.domain.R;
|
|
|
|
import com.ruoyi.common.core.utils.StringUtils;
|
|
|
|
import com.ruoyi.common.core.utils.StringUtils;
|
|
|
|
|
|
|
|
import com.ruoyi.common.redis.service.RedisService;
|
|
|
|
import com.ruoyi.gateway.config.properties.IgnoreWhiteProperties;
|
|
|
|
import com.ruoyi.gateway.config.properties.IgnoreWhiteProperties;
|
|
|
|
import reactor.core.publisher.Mono;
|
|
|
|
import reactor.core.publisher.Mono;
|
|
|
|
|
|
|
|
|
|
|
@ -33,6 +35,8 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private static final Logger log = LoggerFactory.getLogger(AuthFilter.class);
|
|
|
|
private static final Logger log = LoggerFactory.getLogger(AuthFilter.class);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private final static long EXPIRE_TIME = Constants.TOKEN_EXPIRE * 60;
|
|
|
|
|
|
|
|
|
|
|
|
// 排除过滤的 uri 地址,nacos自行添加
|
|
|
|
// 排除过滤的 uri 地址,nacos自行添加
|
|
|
|
@Autowired
|
|
|
|
@Autowired
|
|
|
|
private IgnoreWhiteProperties ignoreWhite;
|
|
|
|
private IgnoreWhiteProperties ignoreWhite;
|
|
|
@ -40,6 +44,9 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
|
|
@Resource(name = "stringRedisTemplate")
|
|
|
|
@Resource(name = "stringRedisTemplate")
|
|
|
|
private ValueOperations<String, String> sops;
|
|
|
|
private ValueOperations<String, String> sops;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
|
|
private RedisService redisService;
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain)
|
|
|
|
public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -54,7 +61,7 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return setUnauthorizedResponse(exchange, "令牌不能为空");
|
|
|
|
return setUnauthorizedResponse(exchange, "令牌不能为空");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
String userStr = sops.get(CacheConstants.LOGIN_TOKEN_KEY + token);
|
|
|
|
String userStr = sops.get(getTokenKey(token));
|
|
|
|
if (StringUtils.isNull(userStr))
|
|
|
|
if (StringUtils.isNull(userStr))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return setUnauthorizedResponse(exchange, "登录状态已过期");
|
|
|
|
return setUnauthorizedResponse(exchange, "登录状态已过期");
|
|
|
@ -66,6 +73,9 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return setUnauthorizedResponse(exchange, "令牌验证失败");
|
|
|
|
return setUnauthorizedResponse(exchange, "令牌验证失败");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 设置过期时间
|
|
|
|
|
|
|
|
redisService.expire(getTokenKey(token), EXPIRE_TIME);
|
|
|
|
// 设置用户信息到请求
|
|
|
|
// 设置用户信息到请求
|
|
|
|
ServerHttpRequest mutableReq = exchange.getRequest().mutate().header(CacheConstants.DETAILS_USER_ID, userid)
|
|
|
|
ServerHttpRequest mutableReq = exchange.getRequest().mutate().header(CacheConstants.DETAILS_USER_ID, userid)
|
|
|
|
.header(CacheConstants.DETAILS_USERNAME, username).build();
|
|
|
|
.header(CacheConstants.DETAILS_USERNAME, username).build();
|
|
|
@ -88,6 +98,11 @@ public class AuthFilter implements GlobalFilter, Ordered
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private String getTokenKey(String token)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return CacheConstants.LOGIN_TOKEN_KEY + token;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* 获取请求token
|
|
|
|
* 获取请求token
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|