今天学习和认识了一下,过滤器和SpringMVC的拦截器的区别,学到了很多的东西,之前一直觉得拦截器就是过滤器实现的,如今想一想还真是一种错误啊,并且看的比较粗浅,没有一个全局而又细致的认识,因为已至深夜,时间缘由,我就把一些网友的观点重点摘录下来,你们仔细看后也必定会有一个比较新的认识(在此很是感谢那些大牛们的无私奉献,分享他们的经验与心得,才能让像我这样的小白有机会站一下大家这些巨人的肩膀,才能少走些弯路)。前端
过滤器和拦截器的区别:java
①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
③拦截器只能对action请求起做用,而过滤器则能够对几乎全部的请求起做用。
④拦截器能够访问action上下文、值栈里的对象,而过滤器不能访问。
⑤在action的生命周期中,拦截器能够屡次被调用,而过滤器只能在容器初始化时被调用一次。框架
⑥拦截器能够获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,能够调用业务逻辑。ide
写了点测试代码,顺便整理一下思路,搞清楚这几者之间的顺序:函数
1.过滤器是JavaEE标准,采用函数回调的方式进行。是在请求进入容器以后,还未进入Servlet以前进行预处理,而且在请求结束返回给前端这之间进行后期处理。post
@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);这个方法中进行的。学习
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)]之间执行。ui
b.preHandle()方法以后,在return ModelAndView以前进行,能够操控Controller的ModelAndView内容。
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
你们还能够参考一下这个电子书的截图: