浅谈java监听器的作用

时间:2022-09-05 16:50:37

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

浅谈java监听器的作用

web监听器

1 什么是web监听器?

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

2 监听器常用的用途

  • 通常使用web监听器做以下的内容:
  • 统计在线人数,利用httpsessionlisener
  • 加载初始化信息:利用servletcontextlistener
  • 统计网站访问量
  • 实现访问监控

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

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

?
1
2
3
4
5
6
7
8
9
10
11
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中添加:

?
1
2
3
<listener>
  <listener-class>com.test.mylistener</listener-class>
</listener>

在jsp中添加访问人数:

?
1
2
3
<body>
  在线人数:<%=session.getattribute("usernumber") %><br/>
</body>

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

浅谈java监听器的作用

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

浅谈java监听器的作用

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

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

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

监听器的分类

1 按照监听的对象划分:

按照监听对象的不同可以划分为三种:

servletcontext监控:对应监控application内置对象的创建和销毁。

当web容器开启时,执行contextinitialized方法;当容器关闭或重启时,执行contextdestroyed方法。

实现方式:直接实现servletcontextlistener接口:

?
1
2
3
4
5
6
7
8
public class myservletcontextlistener implements servletcontextlistener{
  public void contextdestroyed(servletcontextevent sce) {
 
  }
  public void contextinitialized(servletcontextevent sce) {
 
  }
}

httpsession监控:对应监控session内置对象的创建和销毁。

当打开一个新的页面时,开启一个session会话,执行sessioncreated方法;当页面关闭session过期时,或者容器关闭销毁时,执行sessiondestroyed方法。

实现方式:直接实现httpsessionlistener接口:

?
1
2
3
4
5
6
7
8
public class myhttpsessionlistener implements httpsessionlistener{
  public void sessioncreated(httpsessionevent arg0) {
 
  }
  public void sessiondestroyed(httpsessionevent arg0) {
 
  }
}

servletrequest监控:对应监控request内置对象的创建和销毁。

当访问某个页面时,出发一个request请求,执行requestinitialized方法;当页面关闭时,执行requestdestroyed方法。

实现方式,直接实现servletrequestlistener接口:

?
1
2
3
4
5
6
7
8
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方法可以得到属性的名称。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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接口:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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接口:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
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类对象的事件。例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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接口就是实现钝化与活化事件的监听:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
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官网给出的匹配:

浅谈java监听器的作用

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

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

浅谈java监听器的作用

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

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

浅谈java监听器的作用

解决方法:

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

浅谈java监听器的作用

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

?
1
2
3
4
5
6
7
8
9
10
<?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/w-wfy/p/6425357.html