Filter与interceptor的区别

Filter

  • FilterServlet规范制定的,受Servlet容器支持,接口定义在javax.servlet包中。
  • Filter是被Web Server(如Tomcat)调用。
  • Filter 需要在 web.xml 中定义之后才会起作用。
  • Filter只在请求的前后起作用,Servlet对于Filter来说是一个黑盒。
  • Filter的执行顺序是:
    • void init(FilterConfig) - 容器在初始化Filter时调用,在Filter生命周期内仅会被调用一次。方法可以抛出ServletException
    • doFilter(ServletRequest, ServletResponse, FilterChain) - Web容器每一次请求都会调用该方法。该方法将容器的请求和响应作为参数传递进来, FilterChain用来调用下一个Filter
    • void destroy() - 当容器销毁 Filter 实例时调用该方法,可以在方法中销毁资源,该方法在 Filter 的生命周期只会被调用一次。

Interceptor

  • InterceptorSpring容器内的,由Spring框架提供支持。接口HandlerInterceptor定义在org.springframework.web.servlet包中。
  • Interceptor是被Spring调用。
  • Interceptor可以深入到方法前后、异常抛出前后等,比起Filter有更大的弹性。
  • Interceptor还允许用户介入请求的生命周期,可以在请求过程中获取信息,通常与请求更加耦合。
  • Interceptor的执行顺序是:
    • 请求到达DispatcherServlet
    • DispatcherServlet将请求发送至InterceptorInterceptor执行preHandle()方法
    • 请求到达Controller
    • 请求结束后,Interceptor执行postHandle()方法

参考文章

  • Spring Interceptor vs Filter 拦截器和过滤器区别
  • Spring Interceptor vs Filter - 掘金
  • Chapter 10. Filters and Interceptors - Jersey 2.37 User Guide