zoukankan      html  css  js  c++  java
  • Java实战之04JavaWeb-07Listener和Filter

    一、监听器Listener

    javaEE的13们规范中 包括servlet技术和jsp技术

    servlet规范中包括三门技术:(servlet的三大组件)

    servelt技术  Listener技术  Filter技术

    1.什么是监听器

    javaEE中的监听器 监听某些对象的状态变化的

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

    监听器:监听三个域对象的状态变化的接口

    响应行为:当监听器被触发后,需要执行的代码

    监听器的绑定:动作 将监听器注册到事件源身上

    2.监听器的种类(6+2)

    监听器分为两种:

    第一种:监听三个域对象的6个

    第二种:监听要被放置到session域中的对象的状态的(感知监听器)

    3.监听三个域对象的监听器 6个

    第一维度:根据域对象不同分为三种

    第二维度:根据监听域对象的不同状态分为两种

     

    ServletContext域

    HttpSession域

    ServletRequest域

    监听域对象的创建与销毁

    ServletContextListeer

    HttpSessionListener

    ServletRequestListener

    监听域对象中的属性变化的

    ServletContextAttributeListeer

    HttpSessionAttributeListener

    ServletRequestAttributeListener

    4.怎样编写一个监听器

    1)创建一个监听器类去实现监听器接口

    2)覆盖接口中的尚未实现的监听方法

    3)需要在web.xml中配置监听器

    5.ServletContextListener

    监听ServletContext对象的创建与销毁的

    ServletContext对象何时创建于销毁?

    创建:服务器启动就要创建该对象

    销毁:服务器关闭销毁

     1     @Override
     2     public void contextInitialized(ServletContextEvent sce) {
     3         //被监听的对象
     4         ServletContext servletContext = sce.getServletContext();
     5         ServletContext source = (ServletContext) sce.getSource();
     6         System.out.println("servletContext创建了");
     7     }
     8 
     9     @Override
    10     public void contextDestroyed(ServletContextEvent sce) {
    11         System.out.println("servletContext销毁了");
    12     }

    ServletContontextListenter的作用?

    1)进行一些初始化的操作,加载初始化文件,创建初始化的数据

    2)加载一些框架配置文件---使框架介入到web中

    3)执行任务调度----定时器

    6.HttpSessionListener

    监听HttpSession对象的创建与销毁的

    HttpSession域的创建于销毁

    创建:第一次指定request.getSession()

    销毁:服务器关闭、session超时、手动销毁

    1     @Override
    2     public void sessionCreated(HttpSessionEvent se) {
    3         System.out.println("session创建了,jsessionid:"+se.getSession().getId());
    4     }
    5 
    6     @Override
    7     public void sessionDestroyed(HttpSessionEvent se) {
    8         System.out.println("session销毁了,jsessionid:"+se.getSession().getId());
    9     }

    HttpSession的作用?

    记录当前网站的在线的人数

    扫描session过期时间

    7.ServletRequestListener

    监听request对象创建与销毁的

    request对象何时创建与销毁?

    创建:每次访问service方法都会创建request

    销毁:请求响应后request对象销毁

    1     @Override
    2     public void requestInitialized(ServletRequestEvent sre) {
    3         System.out.println("request对象创建了");
    4     }
    5     
    6     @Override
    7     public void requestDestroyed(ServletRequestEvent sre) {
    8         System.out.println("request对象销毁了");
    9     }

    8.监听域对象中属性变化的三个监听器

    ServletContextAttributeListener

    HttpSessionAttributeListener

    ServletRequestAttributeListener

    域对象通用的方法:

    setAttribute:新增属性/修改属性

    getAttribute

    removeAttribute:移除属性

     1 @Override
     2     //域中新增属性
     3     public void attributeAdded(ServletRequestAttributeEvent srae) {
     4         System.out.println("request域中新增:"+srae.getName()+"--"+srae.getValue());
     5     }
     6 
     7     @Override
     8     //删除域中的属性
     9     public void attributeRemoved(ServletRequestAttributeEvent srae) {
    10         System.out.println("request域中删除:"+srae.getName()+"--"+srae.getValue());
    11         
    12     }
    13 
    14     @Override
    15     //修改域中属性
    16     public void attributeReplaced(ServletRequestAttributeEvent srae) {
    17         System.out.println("request域中修改:"+srae.getName()+"--"+srae.getValue());
    18     }

    9.感知监听器

    注意:将要被放置到session中的对象自己可以感知,监听器绑到被放到session域中的对象身上。

    注意:感知监听器不需要配置

    session中对象的状态:

    1)绑定状态  session.setAttribute(“user”,user);

    2)解绑状态  session.removeAttribute(user)

    3)钝化状态  将session中对象的持久化磁盘的过程

    4)活化状态  将磁盘上存储对象信息恢复到session中

    注意:钝化与活化的过程是web容器控制的

    问试题:当服务器中用户比较多时候,怎样去优化?

    其中一方面的回答:从session过多的角度去回答

    绑定与解绑HttpSessionBindingLinstener

    钝化与活化HttpSessionActivationListener

    二、过滤器Filter

    1.filter的简介

    filter是对客户端访问资源的过滤,符合条件放行,不符合条件

    2.快速入门

    步骤:

    1)编写一个过滤器的类实现Filter接口

    2)实现接口中尚未实现的方法(着重实现doFilter方法)

    3)在web.xml中进行配置(主要是配置要对哪些资源进行过滤)

    3.Filter的API详解

    (1)filter生命周期及其与生命周期相关的方法

    Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法

    init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行

    doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法

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

    Filter对象的生命周期:

    Filter何时创建:服务器启动时就创建该filter对象

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

    (2)Filter的API详解

    1)init(FilterConfig)

    其中参数config代表 该Filter对象的配置信息的对象,内部封装是该filter的配置信息。

    2)destory()方法

    filter对象销毁时执行

    3)doFilter方法

    doFilter(ServletRequest,ServletResponse,FilterChain)

    其中的参数:

    ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request和response就是在访问目标资源的service方法时的request和response。

    FilterChain:过滤器链对象,该对象封装所有的filter的引用

     1     @Override
     2     public void init(FilterConfig filterConfig) throws ServletException {
     3         String filterName = filterConfig.getFilterName();
     4         System.out.println(filterName);
     5         ServletContext servletContext = filterConfig.getServletContext();
     6         String initParameter = filterConfig.getInitParameter("aaa");
     7         System.out.println(initParameter);
     8         
     9         System.out.println("filter1创建....");
    10     }
    11 
    12     @Override
    13     public void doFilter(ServletRequest request, ServletResponse response,
    14             FilterChain chain) throws IOException, ServletException {
    15         System.out.println("filter1 running。。。。。");
    16         //代表放行----不进行拦截操作 去访问目标资源
    17         chain.doFilter(request, response);
    18     }
    19 
    20     @Override
    21     public void destroy() {
    22         System.out.println("filter1销毁....");
    23     }

    4.Filter的配置

    1   <!-- 解决中文提交乱码的filter -->
    2   <filter>
    3       <filter-name>EncodingFilter</filter-name>
    4       <filter-class>cn.itcast.encoding.EncodingFilter</filter-class>
    5   </filter>
    6   <filter-mapping>
    7       <filter-name>EncodingFilter</filter-name>
    8       <url-pattern>/*</url-pattern>
    9   </filter-mapping>

    url-pattern配置时

    1)完全匹配  /sertvle1

    2)目录匹配  /aaa/bbb/* ----最多的

    /user/*:访问前台的资源进入此过滤器

    /admin/*:访问后台的资源时执行此过滤器

    3)扩展名匹配  *.abc  *.jsp

    注意:url-pattern可以使用servlet-name替代,也可以混用

    dispatcher:访问的方式(了解)

    REQUEST:默认值,代表直接访问某个资源时执行filter

    FORWARD:转发时才执行filter

    INCLUDE: 包含资源时执行filter

    ERROR:发生错误时 进行跳转是执行filter

    总结Filter的作用?

    1)公共代码的提取

    2)可以对request和response中的方法进行增强(装饰者模式)

    3)进行权限控制

  • 相关阅读:
    linux日志守护进程 syslog
    ORM(一)
    ajax
    python bbs项目代码分析
    jquery基础
    PHP根据概率产生随机数
    用PHP删除文件操作unlink
    实时显示剩余可以输入的文字数
    mysql分表方法实现
    php 输出昨天,今天,明天是星期几的方法
  • 原文地址:https://www.cnblogs.com/minihouseCoder/p/5630608.html
Copyright © 2011-2022 走看看