JSP的Web监听器(Listener)

JSP的Web监听器(Listener)JSP的Web监听器(Listener)

大家好,又见面了,我是你们的朋友全栈君。

在这里插入图片描述

观察者模式

Listener的原理是基于观察者模式的,所谓观察者模式简单来说,就是当被观察者的特定事件被触发(一般这某些方法被调用)后,会通知观察者(调用观察者的方法),观察者可以在自己的方法中来对事件做一些处理。
在我们的JavaWeb中,观察者就是Listener,而被观察者可能有三个ServletContext、HttpSession、ServletRequest。而事件指的就是这些对象的创建、修改和删除等。

  • 什么是web监听器?
      web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,比如ServletContext,HttpSession,ServletRequest的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加处理,实现监控。

  • 监听器常用的用途
      统计在线人数,利用HttpSessionLisener
      加载初始化信息:利用ServletContextListener
      统计网站访问量
      实现访问监控

  • 监听器的创建以及执行过程
    个对在线人数的监控,可以创建如下的监听器:

public class MyListener implements HttpSessionListener{ 
   
    private int userNumber = 0;
    public void sessionCreated(HttpSessionEvent arg0) { 
   
        userNumber++;
        arg0.getSession().setAttribute("userNumber", userNumber);
    }
    public void sessionDestroyed(HttpSessionEvent arg0) { 
   
        userNumber--;
        arg0.getSession().setAttribute("userNumber", userNumber);
    }
}

然后在web.xml中配置该监听器,在web-app中添加:

<listener>
      <listener-class>com.test.MyListener</listener-class>
  </listener>

在JSP中添加访问人数:

<body>
    在线人数:<%=session.getAttribute("userNumber") %><br/>
</body>

当我使用我的浏览器访问时,执行结果如下:
在这里插入图片描述
当打开另一个浏览器访问时:
在这里插入图片描述

监听器的分类

  1. 按照监听的对象划分:
    按照监听对象的不同可以划分为三种:
      ServletContext监控:对应监控application内置对象的创建和销毁。
      当web容器开启时,执行contextInitialized方法;当容器关闭或重启时,执行contextDestroyed方法。
      实现方式:直接实现ServletContextListener接口:
public class MyServletContextListener implements ServletContextListener{ 
   
    public void contextDestroyed(ServletContextEvent sce) { 
   

    }
    public void contextInitialized(ServletContextEvent sce) { 
   

    }
}

HttpSession监控:对应监控session内置对象的创建和销毁。
  当打开一个新的页面时,开启一个session会话,执行sessionCreated方法;当页面关闭session过期时,或者容器关闭销毁时,执行sessionDestroyed方法。
实现方式:直接实现HttpSessionListener接口:

public class MyHttpSessionListener implements HttpSessionListener{ 
   
    public void sessionCreated(HttpSessionEvent arg0) { 
   

    }
    public void sessionDestroyed(HttpSessionEvent arg0) { 
   

    }
}

ServletRequest监控:对应监控request内置对象的创建和销毁。
  当访问某个页面时,出发一个request请求,执行requestInitialized方法;当页面关闭时,执行requestDestroyed方法。
  实现方式,直接实现ServletRequestListener接口:

public class MyServletRequestListener implements ServletRequestListener{ 
   
    public void requestDestroyed(ServletRequestEvent arg0) { 
   
    }
    public void requestInitialized(ServletRequestEvent arg0) { 
   
    }
}
  1. 按照监听事件划分:
      监听事件自身的创建和销毁:同上面的按对象划分。
      监听属性的新增、删除和修改也是划分成三种,分别针对于ServletContext、HttpSession、ServletRequest对象:
       ServletContext,实现ServletContextAttributeListener接口:
    通过调用ServletContextAttribtueEvent的getName方法可以得到属性的名称。
public class MyServletContextAttrListener implements ServletContextAttributeListener{ 
   
    public void attributeAdded(ServletContextAttributeEvent hsbe) { 
   
        System.out.println("In servletContext added :name = "+hsbe.getName());
    }
    public void attributeRemoved(ServletContextAttributeEvent hsbe) { 
   
        System.out.println("In servletContext removed :name = "+hsbe.getName());
    }
    public void attributeReplaced(ServletContextAttributeEvent hsbe) { 
   
        System.out.println("In servletContext replaced :name = "+hsbe.getName());
    }
}

HttpSession,实现HttpSessionAttributeListener接口:

public class MyHttpSessionAttrListener implements HttpSessionAttributeListener{ 
   
    public void attributeAdded(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("In httpsession added:name = "+hsbe.getName());
    }
    public void attributeRemoved(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("In httpsession removed:name = "+hsbe.getName());
    }
    public void attributeReplaced(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("In httpsession replaced:name = "+hsbe.getName());
    }
}

ServletRequest,实现ServletRequestAttributeListener接口:

public class MyServletRequestAttrListener implements ServletRequestAttributeListener{ 
   
    public void attributeAdded(ServletRequestAttributeEvent hsbe) { 
   
        System.out.println("In servletrequest added :name = "+hsbe.getName());
    }
    public void attributeRemoved(ServletRequestAttributeEvent hsbe) { 
   
        System.out.println("In servletrequest removed :name = "+hsbe.getName());
    }
    public void attributeReplaced(ServletRequestAttributeEvent hsbe) { 
   
        System.out.println("In servletrequest replaced :name = "+hsbe.getName());
    }
}
  1. 监听对象的状态:

针对某些POJO类,可以通过实现HttpSessionBindingListener接口,监听POJO类对象的事件。例如:

public class User implements HttpSessionBindingListener,Serializable{ 
   

    private String username;
    private String password;
    
    public String getUsername() { 
   
        return username;
    }

    public void setUsername(String username) { 
   
        this.username = username;
    }

    public String getPassword() { 
   
        return password;
    }

    public void setPassword(String password) { 
   
        this.password = password;
    }

    public void valueBound(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("valueBound name: "+hsbe.getName());
    }

    public void valueUnbound(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("valueUnbound name: "+hsbe.getName());
    }
    
}

Session数据的钝化与活化:

由于session中保存大量访问网站相关的重要信息,因此过多的session数据就会服务器性能的下降,占用过多的内存。因此类似数据库对象的持久化,web容器也会把不常使用的session数据持久化到本地文件或者数据中。这些都是有web容器自己完成,不需要用户设定。
  不用的session数据序列化到本地文件中的过程,就是钝化;
  当再次访问需要到该session的内容时,就会读取本地文件,再次放入内存中,这个过程就是活化。
  类似的,只要实现HttpSeesionActivationListener接口就是实现钝化与活化事件的监听:

public class User implements HttpSessionBindingListener,
HttpSessionActivationListener,Serializable{ 
   

    private String username;
    private String password;
    
    public String getUsername() { 
   
        return username;
    }
    public void setUsername(String username) { 
   
        this.username = username;
    }
    public String getPassword() { 
   
        return password;
    }
    public void setPassword(String password) { 
   
        this.password = password;
    }
    public void valueBound(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("valueBound name: "+hsbe.getName());
    }
    public void valueUnbound(HttpSessionBindingEvent hsbe) { 
   
        System.out.println("valueUnbound name: "+hsbe.getName());
    }
    public void sessionDidActivate(HttpSessionEvent hsbe) { 
   
        System.out.println("sessionDidActivate name: "+hsbe.getSource());
    }
    public void sessionWillPassivate(HttpSessionEvent hsbe) { 
   
        System.out.println("sessionWillPassivate name: "+hsbe.getSource());
    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106671.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jeeplus-vue-boot 8.0版本 前后端分离 跨域 Nginx配置[通俗易懂]

    jeeplus-vue-boot 8.0版本 前后端分离 跨域 Nginx配置[通俗易懂]简单分享一下jeeplus框架部署liunx服务器跨域问题 ,因为我这个是前后端服务器分离所以配置了俩份java后端配置1.跨域后端配置nginx(图-1)上配置 server { listen 80; server_name xxx.xx.xxx; #后端服务域名 #charset koi8-r; #access_log logs/host.access.log main; locatio

    2022年8月20日
    29
  • qt集成ziplib压缩文件和目录「建议收藏」

    qt集成ziplib压缩文件和目录「建议收藏」今天本来想完成压缩文件的任务,结果并没有想象中那么轻松,1.qt自带有压缩工具,但是不考虑,因为qCompress主要用来压缩字节流,就算自己封装成压缩文件,也只能用qt的接口进行解压,可项目需要的是一个通用的压缩工具,2.zlib+quazipzlib官网:http://www.zlib.net/quazip参考http://quazip.sourceforge.net/cla…

    2022年7月26日
    25
  • 游标和动态SQL

    游标和动态SQL游标类别:静态游标(指在编译的时候,游标就与一个select语句进行了静态绑定的游标,这种游标只能作用于一个查询语句)和动态游标(就是希望我们的查询语句在运行的时候才跟游标绑定,为了使用动态游标,必须声明游标变量)。动态游标分两种,分别是强类型和弱类型。强类型的动态游标只能支持查询结果与他类型匹配的这种查询语句,弱类型的动态游标可以支持任何的查询语句。静态游标分为两种,隐式游标和显

    2022年6月23日
    28
  • Intellij IDEA 设置字体大小

    Intellij IDEA 设置字体大小一、通过设置字体size改变字体File—&gt;settings(ctrl+Alt+s)—&gt;Editor—&gt;Font—&gt;size  设置字体大小—&gt;Apply—&gt;ok 即可二、利用鼠标调整字体大小File—&gt;settings(ctrl+Alt+s)—&gt;Editor—&gt;General  右边的cahnge font…

    2022年6月13日
    80
  • C程序设计的抽象思维-递归过程-砝码称重

    C程序设计的抽象思维-递归过程-砝码称重

    2022年2月6日
    51
  • ASP.NET Session详解[通俗易懂]

    ASP.NET Session详解[通俗易懂] (一)描述当用户在Web应用程序中导航ASP.NET页时,ASP.NET会话状态使您能够存储和检索用户的值。HTTP是一种无状态协议。这意味着Web服务器会将针对页面的每个HTTP请求作为独立的请求进行处理。服务器不会保留以前的请求过程中所使用的变量值的任何信息。ASP.NET会话状态将来自限定时间范围内的同一浏览器的请求标识为一个会话,当每个用户首次与这台W

    2022年7月15日
    16

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号