1、相同点
Spring的拦截器Interceptor 和 Servlet的过滤器Filter 有相似之处,比如二者都是AOP编程思想的体现,都能实现权限检查、日志记录等。
2、不同点
Filter | Interceptor | 说明 |
---|---|---|
Filter定义在 javax.servlet 包中 | Interceptor 定义在org.springframework.web.servlet 包中 | … |
Filter 定义在 web.xml 中 | … | … |
Filter在只在 Servlet 前后起作用。Filters 通常将 请求和响应(request/response) 当做黑盒子,Filter 通常不考虑servlet 的实现 | 拦截器能够深入到方法前后、异常抛出前后等,因此拦截器的使用具有更大的弹性。允许用户介入(hook into)请求的生命周期,在请求过程中获取信息,Interceptor 通常和请求更加耦合。 | 在Spring构架的程序中,要优先使用拦截器。几乎所有 Filter 能够做的事情, interceptor 都能够轻松的实现 |
Filter 是 Servlet 规范规定的 | 拦截器既可以用于Web程序,也可以用于Application、Swing程序中 | 使用范围不同 |
Filter 是在 Servlet 规范中定义的,是 Servlet 容器支持的 | 拦截器是在 Spring容器内的,是Spring框架支持的 | 规范不同 |
Filter 不能够使用 Spring 容器资源 | 拦截器是一个Spring的组件,归Spring管理,配置在Spring文件中,因此能使用Spring里的任何资源、对象,例如 Service对象、数据源、事务管理等,通过IoC注入到拦截器即可 | Spring 中使用 interceptor 更容易 |
Filter 是被 Server(like Tomcat) 调用 | Interceptor 是被 Spring 调用 | Filter 总是优先于Interceptor执行,执行顺序:过滤前-拦截前-Action处理-拦截后-过滤后 |
3、使用
何时使用拦截器?何时使用过滤器?
如果是非Spring项目,那么拦截器不能用,只能使用过滤器。
如果是处理controller前后,既可以使用拦截器也可以使用过滤器。
如果是处理DispatcherServlet前后,只能使用过滤器。