拦截器和过滤器

3 篇文章 0 订阅

1.  ajun_studio 的观点


          Filter基于回调函数,我们需要实现的filter接口中doFilter方法就是回调函数,而interceptor则基于java本身的反射机制,这是两者最本质的区别。

          Filter是依赖于servlet容器的,即只能在servlet容器中执行,很显然没有servlet容器就无法来回调doFilter方法。而interceptor与servlet容器无关。

          Filter的过滤范围比Interceptor大,Filter除了过滤请求外通过通配符可以保护页面,图片,文件等等,而Interceptor只能过滤请求。


          Filter的过滤例外一般是在加载的时候在init方法声明,而Interceptor可以通过在xml声明是guest请求还是user请求来辨别是否过滤 。


2.  izard999 的观点

           简单的总结理解:
          1:Filter 对在web.xml中该filter配置的路径进行单向拦截, request匹配Filter的路径时做一次拦截!  这个底层实现没想过, 嘿嘿!
       

          2:interceptor的拦截处理其实就是代理机制! 
           

               Struts2官方文档那个图画的相当明了了。既然是代理,那么是双向拦截,拦截器在action的方法之前执行一次, 之后执行一次!
           

               根据那个图,你可以再对应的去看下StrutsPrepareAndExecuteFilter的源代码,前面一段代码产生Action的环境,判断mapping之类的, 可以跟      

    

               进ExecuteOperations execute这个成员变量,下面如果前面一系列判断都满足的话, 会调用execute.executeAction, 这个里面的实现就是产生action的代理,


               然后通过配置信息, 去获得这个action身上配置了哪些拦截器,然后执行拦截器的代码,拦截器中用ActionInvocation去通知下一个拦截器执行, 等到所有的拦截器都

               拦完了以后,执行action, 随后拦截器又会反向执行一遍(官方确实是这个意思, LZ可以自己写两个拦截器测试下看是不是这么会是)

              

               所以对于Interceptor是不对request进行处理的, 它只是对action起作用。Struts的那个核心过滤器拦截了action的请求之后产生action的代理后进行处理的!

               我只能理解这么多, 呵呵! LZ如果有好的见解记得分享下!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值