什么是拦截器?
拦截器在AOP(Aspect-Oriented Programming)中用于在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作。拦截器是AOP( Aspect-Oriented Programming)的一种实现,底层通过动态代理模式完成。
什么是过滤器?
过滤器可以实现用户在访问某个目标资源之前,对访问的请求和响应进行拦截,它先于与之相关的servlet或JSP页面运行在服务器上。过滤器可附加到一个或多个servlet或JSP页面上,并且可以检查进入这些资源的请求信息。在这之后,过滤器可以作如下的选择:
①以常规的方式调用资源(即,调用servlet或JSP页面)。
②利用修改过的请求信息调用资源。
③调用资源,但在发送响应到客户机前对其进行修改。
④阻止该资源调用,代之以转到其他的资源,返回一个特定的状态代码或生成替换输出。
相同点
Spring的拦截器和Servlet的Filter过滤器有相似之处,比如二者都是AOP编程思想的体现,都能实现权限检查,日志记录等。
不同点
- 拦截器是基于java的反射机制的,而过滤器是基于函数回调。
- 拦截器可以获取IOC容器中的各个bean,而过滤器就不行,因为拦截器是Spring提供并管理的,Spring的功能可以被拦截器使用,在拦截器里注入一个service,可以调用业务逻辑。而过滤器是JavaEE标准,只需要依赖servlet容器,不需要依赖spring。
- 拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
- 拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
- 在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
- 使用范围不同:Filter是Servlet规范规定的,只能用于Web程序中,而拦截器即可以用于Web程序,也可以用于Application、Swing程序中。
- 规范不同:Filter是在Servlet规范中定义的,是Servlet容器支持的,而拦截器是在Spring容器内的,是Spring框架支持的
- 使用资源不同:同其他代码块一样,拦截器也是一个Spring组件,归Spring管理,配置在Spring文件中,因此能使用Spring里面的任何资源、对象。列如Servlet对象、数据源、事务管理等,通过IOC注入拦截器即可。而Filter则不能。
- 深度不同:Filter只在Servlet启动前后起作用。而拦截器能够深入到方法前后、异常抛出前后等,因此拦截器的使用弹性更大一些,所以在使用Spring架构的程序中,优先使用拦截器。
过滤器拦截器运行先后步骤流程图: