1、定义拦截器
@Component
public class TestInterceptor implements HandlerInterceptor {
@Autowired
private RedisUtil redisUtil;
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("进入 Controller 某个方法之前");
String key = "test:key:"+ TokenTool.getUserId();
/**
* boolean 值: 确定了拦截器其余两方法是否执行
*/
if(redisUtil.get(key) != null){
return true;
}else{
//未授权,返回
request.setAttribute("code", 501);
request.getRequestDispatcher("/login/test").forward(request, response);
return false;
}
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("运行 Controller 某个方法时,方法抛出异常将不进入此方法");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("完成 Controller 某个方法");
}
}
2、注入拦截器
@Configuration
public class TestConfig implements WebMvcConfigurer {
@Autowired
private TestInterceptor testInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(testInterceptor).addPathPatterns("/test/**");
}
}