拦截器(Filter) | 过滤器(Interceptor) | |
实现原理 | 基于Java的反射机制(动态代理) | 基于函数回调 |
使用范围 | 一个Spring组件,并由Spring容器管理,并不依赖Tomcat等容器,是可以单独使用的。不仅能应用在web程序中,也可以用于Application、Swing等程序中。 | 实现的是 javax.servlet.Filter 接口,而这个接口是在Servlet规范中定义的,也就是说过滤器Filter 的使用要依赖于Tomcat等容器,导致它只能在web程序中使用。 |
触发时机 | 在请求进入servlet后,在进入Controller之前进行预处理的,Controller 中渲染了对应的视图之后请求结束。 | 在请求进入容器后,但在进入servlet之前进行预处理,请求结束是在servlet处理完以后。 |
请求范围 | Filter 处理中 Interceptor 前置 Interceptor 处理中 Interceptor 后置 Filter 处理中 | |
执行次数 | 只执行了一次,因为拦截器只会对Controller中请求或访问static目录下的资源请求起作用。 | 执行了两次,因为过滤器几乎可以对所有进入容器的请求起作用 |
关于bean | 拦截器可以获取IOC容器中的各个bean,在拦截器里注入一个service,可以调用业务逻辑。 | 无法获取 |
拦截器与Filter的区别
Spring的拦截器与Servlet的Filter有相似之处,比如二者都是AOP编程思想的体现,都能实现权限检查、日志记录等。不同的是:
1.使用范围不同:Filter是Servlet规范规定的,只能用于Web程序中。而拦截器既可以用于Web程序,也可以用于Application、Swing程序中。
2.规范不同:Filter是在Servlet规范中定义的,是Servlet容器支持的。而拦截器是在Spring容器内的,是Spring 框架支持的。
3. 使用的资源不同:同其他的代码块一样,拦截器也是一个Spring的组件,归Spring管理,配置在Spring文件中,因此能使用Spring里的任何资源、对象,例如Service对象、数据源、事务管理等,通过IoC注入到拦截器即可;而Filter则不能。
4. 深度不同:Filter在只在Servlet前后起作用。而拦截器能够深入到方法前后、异常抛出前后等,因此拦截器的使用具有更大的弹性。所以在Spring构架的程序中,要优先使用拦截器。