关于程序员:史上最全面‘java监听器解读读完就能用进项目

35次阅读

共计 6744 个字符,预计需要花费 17 分钟才能阅读完成。

Web 监听器导图详解

监听器是 JAVA Web 开发中很重要的内容,其中波及到的常识,能够参考上面导图:

一、Web 监听器

  1. 什么是 web 监听器?

==============

web 监听器是一种 Servlet 中的非凡的类,它们能帮忙开发者监听 web 中的特定事件,比方 ServletContext,HttpSession,ServletRequest 的创立和销毁;变量的创立、销毁和批改等。能够在某些动作前后减少解决,实现监控。

  1. 监听器罕用的用处

============

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

统计在线人数,利用 HttpSessionLisener

加载初始化信息:利用 ServletContextListener

统计网站访问量

实现拜访监控

  1. 接下来看看一个监听器的创立以及执行过程

=======================

  首先须要创立一个监听器,实现某种接口,例如我想实现一个对在线人数的监控,能够创立如下的监听器:

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

  1. 依照监听事件划分:

=============

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.settingsorg.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 来获取。

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

================

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

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

原文:https://juejin.cn/post/691197…

举荐浏览

=====

程序员年薪百万的飞马打算你据说过吗?

为什么阿里巴巴的程序员成长速度这么快?

从事开发一年的程序员能拿到多少钱?

字节跳动总结的设计模式 PDF 火了,完整版凋谢下载

对于【暴力递归算法】你所不晓得的思路

开拓鸿蒙,谁做零碎,聊聊华为微内核

正文完
 0