拦截器和过滤器有哪些区别?

过滤器(Filter)
它依赖于servlet容器。在实现上,基于函数回调,它可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的,是用来做一些过滤操作,获取我们想要获取的数据,比如:在Javaweb中,对传入的request、response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者Controller进行业务逻辑操作。通常用的场景是:在过滤器中修改字符编码(CharacterEncodingFilter)、在过滤器中修改HttpServletRequest的一些参数(XSSFilter(自定义过滤器)),如:过滤低俗文字、危险字符等。
拦截器(Interceptor):
它依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上,基于Java的反射机制,属于面向切面编程(AOP)的一种运用,就是在service或者一个方法前,调用一个方法,或者在方法后,调用一个方法,比如动态代理就是拦截器的简单实现,在调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在调用方法后打印出字符串,甚至在抛出异常的时候做业务逻辑的操作。由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。但是缺点是只能对controller请求进行拦截,对其他的一些比如直接访问静态资源的请求则没办法进行拦截处理。

  • 拦截器是基于 java 的反射机制的,而过滤器是基于函数回调
  • 拦截器不依赖与 servlet 容器,而过滤器依赖与 servlet 容器
  • 拦截器只能对 action 请求起作用,而过滤器则可以对几乎所有的请求起作用
  • 拦截器可以访问 action 上下文、值栈里的对象,而过滤器不能
  • 在 action 的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
过滤器拦截器都是在Web开发中用来对请求进行处理的工具,它们都可以实现对请求进行拦截、修改、处理等操作,但是它们之间有一些区别过滤器是在Servlet容器中进行处理的,可以对所有的请求进行拦截和处理。过滤器是基于函数回调的,需要在web.xml中配置过滤器的url-pattern,当请求的URL匹配该url-pattern时,过滤器就会被调用。过滤器可以实现对请求的预处理和后处理,如编码转换、防止XSS攻击、权限验证等。 而拦截器则是在Spring框架中进行处理的,主要是针对Controller中方法的调用进行拦截和处理。拦截器是基于AOP(面向切面编程)思想实现的,可以实现类似于过滤器的功能,同时还能够更灵活地控制请求的处理。拦截器可以对请求进行前置处理、后置处理、异常处理等。 总结一下,过滤器拦截器都是用来对请求进行处理的工具,但是它们之间的区别如下: 1. 运行环境不同:过滤器在Servlet容器中进行处理,而拦截器在Spring容器中进行处理; 2. 处理对象不同:过滤器可以对所有的请求进行拦截和处理,而拦截器主要针对Controller中方法的调用进行拦截和处理; 3. 实现方式不同:过滤器是基于函数回调实现的,而拦截器是基于AOP思想实现的。 它们的作用包括但不限于: 1. 过滤非法请求; 2. 统一处理日志记录; 3. 统一处理异常信息; 4. 处理权限验证等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值