过滤器(filter)和拦截器(interceptor)区别

本文探讨了Filter与Interceptor在实现机制上的不同,包括依赖环境、过滤范围、配置方式、访问权限及调用时机等方面,揭示了两者在实际应用中的特点。
一、filter基于filter接口中的doFilter回调函数,interceptor则基于Java本身的反射机制;

二、filter是依赖于servlet容器的,没有servlet容器就无法回调doFilter方法,而interceptor与servlet无关;

三、filter的过滤范围比interceptor大,filter除了过滤请求外通过通配符可以保护页面、图片、文件等,而interceptor只能过滤请求,只对action起作用,在action之前开始,在action完成后结束(如被拦截,不执行action);

四、filter的过滤一般在加载的时候在init方法声明,而interceptor可以通过在xml声明是guest请求还是user请求来辨别是否过滤;

五、interceptor可以访问action上下文、值栈里的对象,而filter不能;

六、在action的生命周期中,拦截器可以被多次调用,而过滤器只能在容器初始化时被调用一次。
在Spring中,过滤器Filter)、拦截器InterceptorAOP(面向切面编程)既有区别又有联系。 ### 区别 - **实现机制**:拦截器基于Java的反射机制,使用代理模式;而过滤器基于函数回调。拦截器不依赖servlet容器,过滤器依赖于servlet容器[^2]。 - **作用范围**:拦截器只能对action起作用,而过滤器可以对几乎所有的请求起作用,能够保护资源[^2]。 - **访问权限**:拦截器可以访问action上下文堆栈里面的对象,过滤器则不能[^2]。 - **执行顺序**:执行顺序为过滤前 - 拦截前 - Action处理 - 拦截后 - 过滤后[^2]。 ### 联系 它们都可以对程序的流程进行拦截处理,起到增强功能控制访问的作用。例如在Spring Boot中,都可以对请求进行一定的前置或后置处理。而且它们都可以用于实现一些通用的功能,如日志记录、权限验证等。 ### 代码示例 以下是简单的过滤器拦截器AOP的代码示例: #### 过滤器示例 ```java import javax.servlet.*; import java.io.IOException; public class MyFilter implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤前处理 System.out.println("Filter: Before processing"); chain.doFilter(request, response); // 过滤后处理 System.out.println("Filter: After processing"); } } ``` #### 拦截器示例 ```java import org.springframework.web.servlet.HandlerInterceptor; import org.springframework.web.servlet.ModelAndView; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 拦截前处理 System.out.println("Interceptor: Before handler execution"); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 拦截后处理 System.out.println("Interceptor: After handler execution"); } } ``` #### AOP示例 ```java import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.stereotype.Component; @Aspect @Component public class MyAspect { @Pointcut("execution(* com.example.service.*.*(..))") public void serviceMethods() {} @Before("serviceMethods()") public void beforeServiceMethod(JoinPoint joinPoint) { // 增强处理(前置通知) System.out.println("AOP: Before service method execution"); } @After("serviceMethods()") public void afterServiceMethod(JoinPoint joinPoint) { // 增强处理(后置通知) System.out.println("AOP: After service method execution"); } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值