一般情况下,对来自浏览器的请求,在该请求进行业务逻辑处理之前,我们是可以进行拦截处理的,实现的方式有两种,分别是基于Tomcat的Filter,和基于SpringMVC的HandlerInterceptor。
- 基于Tomcat的Filter实现拦截,可以利用SpringBoot的FilterRegistrationBean实现Filter和Spring的整合,向Tomcat注册自定义Filter,使Filter可以在Servlet处理请求之前拦截请求。
- 基于SpringMVC中的拦截器HandlerInterceptor实现拦截器,拦截器可以在Controller中相应的Action方法处理请求前进行拦截。
Filter和Interceptor的区别:
- Filter直接依赖Servlet容器,而Interceptor不直接依赖于Servlet容器
- Filter对Http请求起作用,而Interceptor只能对action请求起作用。
- Interceptor可以访问Action的上下文值栈里的对象,而Filter不能。
- 在action的生命周期里,Interceptor可以被多次调用,而Filter针对一个请求只会被调用一次。
- Filter在过滤是只能对request和response进行操作,而interceptor可以对request、response、handler、 modelAndView、exception进行操作。
package org.springframework.web.servlet public interface HandlerInterceptor {
/** 预处理回调方法,实现处理器的预处理(例如登录校验) 第三个参数为响应的处理器,一般是自定 义 的Controller * 返回值:true 表示继续流程,如调用下一个拦截器或者是处理器;false表示流程中断,不会再 调 用其他的响应器 * 或者处理器 */
default boolean preHandle(HttpServletRequest request, HttpServletResponse
response, Object handler) throws Exception {
return true; }
/** 后处理回调方法,实现处理器的后处理(但是在渲染视图之前),此时我们可以通过 ModelAndView 对模型数据进行 * 处理或者对视图进行处理。 */
default void postHandle(HttpServletRequest request, HttpServletResponse
response, Object handler, @Nullable ModelAndView modelAndView) throws Exception
{
}
/** 整个请求处理完毕回调方法,即在视图渲染完毕时回调,比如性能监控中我们可以在此记录结束时 间 并输出消耗时间 * 还可以进行一些资源的清理,类似于try...catch...finally中的finally。 */
default void afterCompletion(HttpServletRequest request, HttpServletResponse
response, Object handler, @Nullable Exception ex) throws Exception {
} }
代码实现
/*** 自定义拦截器 */
public class Intercept implements HandlerInterceptor {
@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("执行了prehandler");return false;}
}
/*** 配置类 */
@Configuration
public class MyWebMvcConfigurer implements WebMvcConfigurer {
@AutowiredIntercept intercept;@Overridepublic void addInterceptors(InterceptorRegistry registry) {
// ** 表示拦截所有的请求registry.addInterceptor(intercept).addPathPatterns("/**");}
}