java Web监听器导图详解

news/2024/7/7 7:05:42

监听器是JAVA Web开发中很重要的内容,其中涉及到的知识,可以参考下面导图:

Web监听器

  1 什么是web监听器?

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

  2 监听器常用的用途

  通常使用Web监听器做以下的内容:

  统计在线人数,利用HttpSessionLisener

  加载初始化信息:利用ServletContextListener

  统计网站访问量

  实现访问监控

  3 接下里看看一个监听器的创建以及执行过程

   首先需要创建一个监听器,实现某种接口,例如我想实现一个对在线人数的监控,可以创建如下的监听器:

复制代码
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>

  当我使用我的浏览器访问时,执行结果如下:

  当打开另一个浏览器访问时:

  由于打开另一个浏览器访问,相当于另一个会话,因此在线人数会增加。

  对于3.0版本的Servlet来说,还支持使用注解的方式进行配置。

  那么接下来看看都有哪些监听器以及方法吧!

监听器的分类

  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) {

    }
}
复制代码

 

  2 按照监听事件划分:

  2.1 监听事件自身的创建和销毁:同上面的按对象划分。

  2.2 监听属性的新增、删除和修改:

  监听属性的新增、删除和修改也是划分成三种,分别针对于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());
    }

}
复制代码

  2.3 监听对象的状态:

  针对某些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());
    }
    
}
复制代码

Servlet版本与Tomcat版本

  首先看一下Tomcat官网给出的匹配:

  如果版本不匹配,那么tomcat是不能发布该工程的,首先看一下版本不匹配时,会发生什么!

  我试图创建一个web工程,并且选取了Servlet3.0版本:

  然后我想要在tomcat6中发布,可以看到报错了!

  JDK版本不对....这是在平时开发如果对Servlet不熟悉的web新手,常犯的错误。

  解决方法:

  1 在创建时,直接发布到Tomcat容器中,此时Servlet仅仅会列出Tomcat支持的版本:

  2 修改工程Servlet版本配置信息,文件为:工作目录\SessionExample\.settings\org.eclipse.wst.common.project.facet.core.xml

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<faceted-project>
  <runtime name="Apache Tomcat v6.0"/>
  <fixed facet="java"/>
  <fixed facet="wst.jsdt.web"/>
  <fixed facet="jst.web"/>
  <installed facet="java" version="1.7"/>
  <installed facet="jst.web" version="2.5"/>
  <installed facet="wst.jsdt.web" version="1.0"/>
</faceted-project>
复制代码

getAttribute与getParameter的区别

  这部分是对JSP的扩展,经常在JSP或者Servlet中获取数据,那么getAttribute与getParameter有什么区别呢?

  1 从获取到数据的来源来说:

  getAttribtue获取到的是web容器中的值,比如:

  我们在Servlet中通过setAttribute设定某个值,这个值存在于容器中,就可以通过getAttribute方法获取;

 

  getParameter获取到的是通过http传来的值,比如这样一个http请求:

http:localhost:8080/test/test.html?username=xingoo

  还有其他的GET和POST方式,都可以通过getParameter来获取。

  2 从获取到的数据类型来说:

  getAttribute返回的是一个对象,Object。

  getParameter返回的是,前面页面中某个表单或者http后面参数传递的值,是个字符串。

转载:http://www.cnblogs.com/xing901022/p/4378727.html


http://www.niftyadmin.cn/n/3780513.html

相关文章

发布成功 html,发布成功页.html

&#xfeff;发布成功页$axure.utils.getTransparentGifPath function() { return resources/images/transparent.gif; };$axure.utils.getOtherPath function() { return resources/Other.html; };$axure.utils.getReloadPath function() { return resources/reload.html; …

C#导入导出数据到Excel的通用类代码

Excel文件导入导出,需引用Microsoft Excel 11.0 Object Library /// //Purpose&#xff1a;Excel文件导入导出,需引用Microsoft Excel 11.0 Object Library //Author: Dangmy //Date: 2007-03-09 //Version: 1.0 ///public class ExcelIO {private int _ReturnStatus;private s…

thread.sleep后没有恢复执行_关于执行和解

执行和解知多少1.执行和解协议是什么东东&#xff1f;答&#xff1a;执行和解协议是指在执行过程中&#xff0c;执行当事人达成和解意向并在签署后提交法院确认后的合同。对喽&#xff0c;执行和解协议就是一份合同。可以签署后提交法法院&#xff0c;也可以记录在法庭笔录中。…

监控之美--prometheus配置文件动态管理

Prometheus是一套开源的监控、报警解决方案&#xff0c;是由SoundCloud公司开发的&#xff0c;从 2012 年开始编写代码&#xff0c;再到 2015 年 开源以来&#xff0c;该项目有非常活跃的社区和开发人员&#xff0c;目前在全世界最大的男友社区上已经有了1.1w多star&#xff1b…

网易--赶去公司

终于到周末啦&#xff01;小易走在市区的街道上准备找朋友聚会&#xff0c;突然服务器发来警报,小易需要立即回公司修复这个紧急bug。假设市区是一个无限大的区域&#xff0c;每条街道假设坐标是(X&#xff0c;Y)&#xff0c;小易当前在(0&#xff0c;0)街道&#xff0c;办公室…

计算机原理南开在线作业2020,南开大学-2020春学期《计算机原理》在线作业

南开大学-2020春学期《计算机原理》在线作业20春学期( 1709、 1803、 1809、 1903、 1909、2003)《计算机原理》在线作业 --------------------------- 单选题 1.1、连接计算机与计算机之间的总线属于 ()总线A.内 B.系统 C.通信 D.都不对正确答案 :C 2.某数在计算机中用 8421BC…

CAS算法的定义

为什么80%的码农都做不了架构师&#xff1f;>>> CAS (compare and swap)包含三个参数,CAS(V,E,N),V表示要更新的变量,E表示期望的值,N表示新值,仅当VE的时候才会将V的值设置为N,如果V值和E值不同,则证明其他线程做了更新,则当前线程什么也不做. Java自旋锁应用-原子…

计算机检测与维修课程设计总结,(计算机课程设计总结报告.ppt

(计算机课程设计总结报告首先&#xff0c;我初步了解了C#语言的编程方法和原则&#xff0c;并学会了编写C#程序。其次&#xff0c;使我更深层次的理解到C#语言是一种面向对象的语言&#xff0c;具有可视化编程的特点且代码具有可移植等特点。本次课程设计是实现一个UDP即时通讯…