您的位置:首页 > 职场人生

java程序员菜鸟入门之十四过滤器、监听器、拦截器

2018-01-22 22:34 288 查看

一、过滤器

1、概述:filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目
标资源访问前后进行逻辑处理

                作用:1)公共代码的提取;2)可以对request和response中的方法进行增强(装饰者模式/动态代理);3)进行权限控制

2、Filter的API详解:init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行

                                doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法(ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request个该response就是在访问目标资源的service方法时的request和response)

                                  FilterChain:过滤器链对象,通过该对象的doFilter方法可以放行该请求

                                  destory():代表是filter销毁方法 当filter对象销毁时执行该方法



3、Filter的配置:

     

        

4、Filter生命周期:Filter何时创建:服务器启动时就创建该filter对象

                              Filter何时销毁:服务器关闭时filter销毁

二、监听器

1、概述:监听器就是监听某个对象的的状态变化的组件

               事件源:被监听的对象  ----- 三个域对象 request  session  servletContext

              监听器:监听事件源对象  事件源对象的状态的变化都会触发监听器 ---- 6+2

              注册监听器:将监听器与事件源进行绑定 

              响应行为:监听器监听到事件源的状态变化时 所涉及的功能代码 ---- 程序员编写代码

2、八大监听器:

          1.监听三大域对象的创建与销毁的监听器

                  (1)监听ServletContext域的创建与销毁的监听器ServletContextListener

                          1)Servlet域的生命周期

                          何时创建:服务器启动创建

                          何时销毁:服务器关闭销毁

                         2)监听器的编写步骤                                                                                                                                     a、编写一个监听器类去实现监听器接口                                                                      
                                  b、覆盖监听器的方法

                         c、需要在web.xml中进行配置

                        3)监听的方法:



                    4)配置文件



                   5)ServletContextListener监听器的主要作用

                   a、初始化的工作:初始化对象 初始化数据 ---- 加载数据库驱动  连接池的初始化

                   b、加载一些初始化的配置文件 --- spring的配置文件

                   c、任务调度----定时器----Timer/TimerTask

                 任务调度:



          (2)监听Httpsession域的创建于销毁的监听器HttpSessionListener

                    1)HttpSession对象的生命周期

                    何时创建:第一次调用request.getSession时创建

                    何时销毁:服务器关闭销毁  session过期  手动销毁

                   2)HttpSessionListener的方法



             (3)监听ServletRequest域创建与销毁的监听器ServletRequestListener

                        1)ServletRequest的生命周期

                        创建:每一次请求都会创建request

                        销毁:请求结束

                        2)ServletRequestListener的方法



               4.监听三大域对象的属性变化的

                        (1)域对象的通用的方法:

                        setAttribute(name,value)

                        --- 触发添加属性的监听器的方法   

                        --- 触发修改属性的监听器的方法 

                       getAttribute(name)

                       removeAttribute(name)  

                       --- 触发删除属性的监听器的方法 

                      (2)ServletContextAttibuteListener监听器



                      (3) HttpSessionAttributeListener监听器

                      (4) ServletRequestAriibuteListenr监听器

             5.与session中的绑定的对象相关的监听器(对象感知监听器)

                     (1)即将要被绑定到session中的对象有几种状态

                     绑定状态:就一个对象被放到session域中

                     解绑状态:就是这个对象从session域中移除了

                     钝化状态:是将session内存中的对象持久化(序列化)到磁盘

                     活化状态:就是将磁盘上的对象再次恢复到session内存中

                    (2)绑定与解绑的监听器HttpSessionBindingListener



                 (3)钝化与活化的监听器HttpSessionActivationListener

                 可以通过配置文件 指定对象钝化时间 --- 对象多长时间不用被钝化

                 在META-INF下创建一个context.xml

三、拦截器

1、概述:是在面向切面编程的就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,在你调用方 法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。

2、自定义拦截器的步骤

    1、自定义一个实现了Interceptor接口的类,或者继承抽象类AbstractInterceptor。

    2、在配置文件中注册定义的拦截器。

    3、在需要使用Action中引用上述定义的拦截器,为了方便也可以将拦截器定义为默认的拦截器,这样在不加特殊说明的情况下,所有的

四、过滤器与拦截器的区别

  1、拦截器是基于java的反射机制的,而过滤器是基于函数回调。

  2、拦截器不依赖与servlet容器,过滤器依赖与servlet容器。

  3、拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。

  4、拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。

  5、在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调
a048
用一次。

  6、拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息