浅谈java监听器的作用

监听器是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后面参数传递的值,是个字符串。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

时间: 2017-09-02

JavaWeb监听器Listener实例解析

首先来介绍一下什么是监听器: 监听器-就是一个实现待定接口的普通Java程序,此程序专门用于监听另外一个类的方法调用. 这是使用观察者模式的. 什么是观察者模式: 定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知自动更新. 示例: GUI编程中的addXxxxListener都是观察者模式. 比如为按钮点击添加监听事件,为键盘添加监听等等- 观察者模式的三个重要类: 被监听的事件源,也就是我们在使用的对象. 注册的那个监听器,是专门用来监听当前使用的对象的.

java web监听器统计在线用户及人数

在线用户使用HttpSessionListener监听器统计  每当一个session会话建立  在线用户人数+1 每当一个session会话销毁 在线用户人数-1 使用ServletRequestListener监听器统计用户信息 每当一个request建立  将当前用户放入集合 每当session会话销毁  将当前用户移出集合 我使用的是Servlet3.0  监听器直接使用注解@webListener即可 不用在web.xml中布局 在web.xml中配置session-timeout标签

java使用监听器实现一个统计网站在线人数的示例

本文主要介绍了java使用监听器实现一个统计网站在线人数的示例,具有一定的参考价值,有需要的朋友可以了解一下. (1)创建一个监听器实现类 要大致统计一个网站的在线人数,首先,可以通过ServletContextListener监听,当Web应用上下文启动时,在ServletContext中添加一个List,用来准备存放在线的用户名:然后,可以通过HttpSessionAttributeListener监听,当用户登录成功把用户名设置到Session中时同时将用户名存放到ServletConte

Java中的拦截器、过滤器、监听器用法详解

本文实例讲述了Java中的拦截器.过滤器.监听器用法.分享给大家供大家参考,具体如下: 一.拦截器 :是在面向切面编程的就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法比如动态代理就是拦截器的简单实现,在你调用方 法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作. 1.Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,

深入学习JavaWeb中监听器(Listener)的使用方法

一.监听域对象中属性的变更的监听器 域对象中属性的变更的事件监听器就是用来监听 ServletContext, HttpSession, HttpServletRequest 这三个对象中的属性变更信息事件的监听器. 这三个监听器接口分别是ServletContextAttributeListener, HttpSessionAttributeListener 和ServletRequestAttributeListener,这三个接口中都定义了三个方法来处理被监听对象中的属性的增加,删除和替换

Java基础 Servlet监听器详解

Java基础 Servlet监听器详解 1 概念:Servlet监听器,用来监听web容器的一些对象状态的变化,主要是ServletContext.HttpSession.HttpServletRequestl三类对象状态.Servlet的监听器 2  Servlet2.4和JSP2.0规范中一共定义了有八个接口类和六种事件. 3 web.xml中定义Servlet的url-pattern时如果url-pattern的值的"/",则说明该Servlet是该项目的默认Servlet,当请

利用java监听器实现在线人数统计

1.在工程中创建监听类SessionListener 并且实现HttpSessionListener接口,代码如下 import javax.servlet.http.HttpSessionEvent; import javax.servlet.http.HttpSessionListener; public class SessionListener implements HttpSessionListener { private static int count = 0; public vo

浅析JAVA中过滤器、监听器、拦截器的区别

1.过滤器:所谓过滤器顾名思义是用来过滤的,在java web中,你传入的request,response提前过滤掉一些信息,或者提前设置一些参数,然后再传入servlet或者struts的action进行业务逻辑,比如过滤掉非法url(不是login.do的地址请求,如果用户没有登陆都过滤掉),或者在传入servlet或者struts的action前统一设置字符集,或者去除掉一些非法字符(聊天室经常用到的,一些骂人的话).filter 流程是线性的, url传来之后,检查之后,可保持原来的流程

servlet监听器的学习使用(三)

本文为大家分享了servlet监听器的具体学习内容,供大家参考,具体内容如下 1.什么是servlet监听器? servlet监听器也叫web监听器.是servlet中一种特殊类.能够帮助开发者监听web应用中的特定事件.比如ServletContext,ServletSession,ServletRequest的创建和销毁,变量的创建和销毁等. 2 监听器常用的用途 通常使用Web监听器做以下的内容: 统计在线人数,利用HttpSessionLisener 加载初始化信息:利用ServletC

快速学习JavaWeb中监听器(Listener)的使用方法

一.监听器介绍 1.1.监听器的概念 监听器是一个专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生情况时,立即采取相应的行动.监听器其实就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上述事件后,监听器某个方法立即被执行. 1.2.监听器案例--监听window窗口的事件监听器 package me.gacl.listener.demo; import java.awt.Frame; imp

关于javaWeb中405错误的解决方法

今天写了一个servlet,可是一直405报错,开始以为web.xml里面的servlet配置有问题,可是那样的话应该报404错误啊 最后才发现在重写doPost和doGet方法的时候,写成了dopost和doget,因为java对大小写很敏感,故相当于没有重新httpservelt里面的方法. 反思:编程需谨慎!!! 以上这篇关于javaWeb中405错误的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们.

详解JavaWeb中的 Listener

一.基本概念 JavaWeb里面的listener是通过观察者设计模式进行实现的.对于观察者模式,这里不做过多介绍,大概讲一下什么意思. 观察者模式又叫发布订阅模式或者监听器模式.在该模式中有两个角色:观察者和被观察者(通常也叫做主题).观察者在主题里面注册自己感兴趣的事件,当这个事件发生时,主题会通过回调接口的方式通知观察者. 举个生活中的例子:订阅报纸.任何一个家庭或个人都可以向报社订阅报纸.这里报社就是"主题",家庭就是"观察者".比如家庭需要订阅明天早晨的报

ASP.NET学习CORE中使用Cookie身份认证方法

大家在使用ASP.NET的时候一定都用过FormsAuthentication做登录用户的身份认证,FormsAuthentication的核心就是Cookie,ASP.NET会将用户名存储在Cookie中. 现在到了ASP.NET CORE的时代,但是ASP.NET CORE中没有FormsAuthentication这个东西,那么怎么做身份认证呢?答案是ASP.NET CORE已经为我们内置了Cookie身份认证的功能,而且使用起来非常方便,注意本文是基于ASP.NET CORE 2.0版本

JavaWeb中Session对象的学习笔记

一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务. 二.Session和Cookie的主要区别 Cookie是把用户的数据写给用户的浏览器. Session技术把用户的数据写到用户独占的sess

如何快速学习正则表达式

正则表达式概念 正则表达式,又称正规表示法.常规表示法(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表达式使用单个字符串来描述.匹配一系列符合某个句法规则的字符串.在很多文本编辑器里,正则表达式通常被用来检索.替换那些符合某个模式的文本. 在日常工作中,我们经常写正则表达式,比如在表单中经常用来验证用户输入的格式是否正确,我们就会用到正则表达式;可以把正则表达式看做是可以描述问题的语言,它就是专门为模式匹配而设计的 --

学习javaweb如何配置Tomcat的热启动

(1)我们初学者在学习javaweb的时候每次更改项目都需要重新部署项目,这样的二话太麻烦 (2)使用tomcat的热启动就可以解决这个问题: 在tomcat目录下:找到 conf ----context.xml 打开 填写圈中的 就好了! (3)如果你的tomcat是自己的myeclipse中自带的话 就需要在自己的项目中找到 是在自己的工作区间下: 这是我的工作区间 就是第一个 点进去 有一个 .me_tcat 看到了conf 其他的过程和上述一样!

基于dubbo中Listener的实现方法

这里继续dubbo的源码旅程,在过程中学习它的设计和技巧,看优秀的代码,我想对我们日程编码必然有帮助的.而那些开源的代码正是千锤百炼的东西,希望和各位共勉. 拿ProtocolListenerWrapper为例子,看源码的时候发现它是一个装饰类的标准实现有一个自身的复制构造函数,把被包装者复制进来,然后结合装饰部分的操作.看下ProtocolListenerWrapper类有这样的代码: public class ProtocolListenerWrapper implements Protoc

javaweb中Filter(过滤器)的常见应用

一.统一全站字符编码 通过配置参数charset指明使用何种字符编码,以处理Html Form请求参数的中文问题 package me.gacl.web.filter; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException;