Spring Boot2.x.x全局token拦截器
Result 自定义封装请看另外的文章 Result封装
TokenInterceptorHandler.java
java
package com.sky.handler;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.sky.result.Result;
import com.sky.utils.RedisUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@Slf4j
@Component
public class TokenInterceptorHandler implements HandlerInterceptor {
private static final ObjectMapper objectMapper = new ObjectMapper();
@Resource
private RedisUtils redisUtils;
private boolean writeJson(HttpServletResponse response, Result<?> result) throws Exception {
response.setStatus(HttpStatus.UNAUTHORIZED.value());
response.setContentType("application/json;charset=UTF-8");
response.getWriter().write(objectMapper.writeValueAsString(result));
return false;
}
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
String token = request.getHeader("Authorization");
return true; // 接全部接口不做检验 如果需要检验接口 把下面注释的放开
// // 如果请求不需要登录,可在这里设置白名单
// String uri = request.getRequestURI();
// if (uri.startsWith("/public") || uri.equals("/login")) {
// return true;
// }
// if (token == null || token.isEmpty()) {
// return writeJson(response, Result.unauthorized("未登录"));
// }
//
// String key = redisUtils.getRedisName() + token;
// String userJson = (String) redisUtils.get(key);
// if (userJson == null) {
// return writeJson(response, Result.unauthorized("登录已过期"));
// }
//
// // 可在这里把用户信息放入 request,方便 Controller 使用
// request.setAttribute("userInfo", userJson);
//
// return true; // token 校验通过
}
}
WebConfig.java
java
package com.ruoyi.sky.config;
import com.ruoyi.sky.handler.TokenInterceptorHandler;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import java.io.Serializable;
//@Configuration // 配置类通常使用@Configuration注解进行标记,表示该类是一个配置类
@Configuration
public class WebConfig implements WebMvcConfigurer {
private final TokenInterceptorHandler tokenInterceptorHandler;
@Autowired
public WebConfig(TokenInterceptorHandler tokenInterceptorHandler) {
this.tokenInterceptorHandler = tokenInterceptorHandler;
}
/*
addPathPatterns("/**") 表示所有路径都会进入拦截器。
excludePathPatterns(...) 表示这些路径不拦截。
*/
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(tokenInterceptorHandler)
.addPathPatterns("/**")
.excludePathPatterns(
"/admin/employee/login",
"/logout",
"/public/**",
"/swagger-ui/**",
"/v2/api-docs",
"/webjars/**"
);
}
}
RedisUtils.java 封装
java
package com.sky.utils;
import com.sky.constant.RedisConstant;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import java.util.concurrent.TimeUnit;
@Component
public class RedisUtils {
@Autowired
private RedisTemplate redisTemplate;
/**
* 写入缓存(默认不过期)
*/
public void set(String key, Object value) {
redisTemplate.opsForValue().set(key, value);
}
/**
* 写入缓存,并设置过期时间(单位:秒)
*/
public void set(String key, Object value, long timeoutSeconds) {
redisTemplate.opsForValue().set(key, value, timeoutSeconds, TimeUnit.SECONDS);
}
/**
* 获取缓存
*/
public Object get(String key) {
return redisTemplate.opsForValue().get(key);
}
/**
* 删除缓存
*/
public void delete(String key) {
redisTemplate.delete(key);
}
/**
* 判断 key 是否存在
*/
public boolean exists(String key) {
return Boolean.TRUE.equals(redisTemplate.hasKey(key));
}
public String getRedisName() {
return RedisConstant.REDIS_KEY; // 返回的是列如 login:user:
}
}