Java过滤器与SpringMVC拦截器之间的关系与区别

       今天学习和认识了一下,过滤器和SpringMVC的拦截器的区别,学到了很多的东西,之前一直觉得拦截器就是过滤器实现的,如今想一想还真是一种错误啊,并且看的比较粗浅,没有一个全局而又细致的认识,因为已至深夜,时间缘由,我就把一些网友的观点重点摘录下来,你们仔细看后也必定会有一个比较新的认识(在此很是感谢那些大牛们的无私奉献,分享他们的经验与心得,才能让像我这样的小白有机会站一下大家这些巨人的肩膀,才能少走些弯路)。html

 

  过滤器和拦截器的区别:前端

  ①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
  ②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
  ③拦截器只能对action请求起做用,而过滤器则能够对几乎全部的请求起做用。
  ④拦截器能够访问action上下文、值栈里的对象,而过滤器不能访问。
  ⑤在action的生命周期中,拦截器能够屡次被调用,而过滤器只能在容器初始化时被调用一次。
java

  ⑥拦截器能够获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,能够调用业务逻辑。框架

  写了点测试代码,顺便整理一下思路,搞清楚这几者之间的顺序:ide

  1.过滤器是JavaEE标准,采用函数回调的方式进行。是在请求进入容器以后,还未进入Servlet以前进行预处理,而且在请求结束返回给前端这之间进行后期处理。函数

 
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        System.out.println("before...");
        chain.doFilter(request, response);
        System.out.println("after...");
    }
 

  chain.doFilter(request, response);这个方法的调用做为分水岭。事实上调用Servlet的doService()方法是在chain.doFilter(request, response);这个方法中进行的。post

  2.拦截器是被包裹在过滤器之中的。学习

 
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("preHandle");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("postHandle");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion");
    }
 

  a.preHandle()这个方法是在过滤器的chain.doFilter(request, response)方法的前一步执行,也就是在 [System.out.println("before...")][chain.doFilter(request, response)]之间执行。测试

  b.preHandle()方法以后,在return ModelAndView以前进行,能够操控Controller的ModelAndView内容。ui

  c.afterCompletion()方法是在过滤器返回给前端前一步执行,也就是在[chain.doFilter(request, response)][System.out.println("after...")]之间执行。

  3.SpringMVC的机制是由同一个Servlet来分发请求给不一样的Controller,其实这一步是在Servlet的service()方法中执行的。因此过滤器、拦截器、service()方法,dispatc()方法的执行顺序应该是这样的,大体画了个图:其实很是好测试,本身写一个过滤器,一个拦截器,而后在这些方法中都加个断点,一路F8下去就得出告终论。

  

 

  总结:拦截器功在对请求权限鉴定方面确实颇有用处,在我所参与的这个项目之中,第三方的远程调用每一个请求都须要参与鉴定,因此这样作很是方便,并且他是很独立的逻辑,这样作让业务逻辑代码很干净。和框架的其余功能同样,原理很简单,使用起来也很简单,大体看了下SpringMVC这一部分的源码,其实仍是比较容易理解的。

  咱们项目中仅仅用到了preHandle这个方法,而未用其余的,框架提供了一个已经实现了拦截器接口的适配器类HandlerInterceptorAdapter,继承这个类而后重写一下须要用到的方法就好了,能够少几行代码,这种方式Java中不少地方都有体现。

以上部分是摘自神同样存在的博客参考了一下这个帖子:http://haohaoxuexi.iteye.com/blog/1750680

你们还能够参考一下这个电子书的截图: