适用场景
像是页面的登录验证处理,权限校验,登录日志的处理.
实现步骤
- 创建⾃定义拦截器,实现 HandlerInterceptor 接⼝的 preHandle(执⾏具体⽅法之前的预处理⽅法.
- 将⾃定义拦截器加⼊ WebMvcConfigurer 的 addInterceptors ⽅法中.
下面以登录验证为例,实现拦截器.
实现HandlerInterceptor接口,并重写preHandle方法(在业务处理器处理请求之前被调用)
@Component
public class Interceptor implements HandlerInterceptor {//preHandle方法返回true表示能通过,并继续执行原本的下一步.//返回false表示不能通过,执行其他程序或返回.@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {HttpSession session = request.getSession(false);if(session != null && session.getAttribute("user") != null){return true;//验证用户已为登录状态}//用户未登录response.sendRedirect("login.html");return false;}
}
实现WebMvcConfigurer接口,将上面实现的拦截器加入到其中
@Configuration
public class MyConfig implements WebMvcConfigurer {@Autowired//注入拦截器的对象Interceptor Interceptor;@Override//添加拦截器public void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(Interceptor)//将拦截器加入.addPathPatterns("/**")//拦截所有的方法.excludePathPatterns("/**/*.html")//放开(不拦截)以.html结尾的文件.excludePathPatterns("/user/login");//放开url为user/login的方法}
}