session监听

servlet中对session的监听有很多接口,功能很灵活,最常用的是监听Session和Attribute。这里要澄清一下概念,servlet中的session监听和Attribute监听含义有差别,session监听指的不是我们一般所理解的放置一个session或者销毁一个session,这是Attribute监听的功能,因为servlet中放置session的语法是 session.setAttribute(“session名”,要放入的对象)。而session监听,监听的是HTTP连接,只要有用户与 server连接,就算连接的是一个空白的jsp页面,也会触发session事件,所以此处的session实际上指的是connection,用来统计当前在线用户数最合适了。不知道我说清楚了没有。下面分别讲解这两种监听方式。

1、 session监听

首先编写一个session监听类,实作HttpSessionListener接口,它的作用是计算当前有多少个在线用户:
Java代码

1. package org.bromon.test;
2.
3. import javax.servlet.*;
4. import javax.servlet.http.*;
5.
6. public class SessionCount implements HttpSessionListener{
7. private static int count=0;
8.
9. public void sessionCreated(HttpSessionEvent se){
10. count++;
11. System.out.println(“session创建:”+new java.util.Date());
12. }
13.
14. public void sessionDestroyed(HttpSessionEvent se){
15. count--;
16. System.out.println(“session销毁:”+new java.util.Date());
17. }
18.
19. public static int getCount(){
20. return(count);
21. }
22. }

package org.bromon.test;

import javax.servlet.*;
import javax.servlet.http.*;

public class SessionCount implements HttpSessionListener{
private static int count=0;

public void sessionCreated(HttpSessionEvent se){
count++;
System.out.println(“session创建:”+new java.util.Date());
}

public void sessionDestroyed(HttpSessionEvent se){
count--;
System.out.println(“session销毁:”+new java.util.Date());
}

public static int getCount(){
return(count);
}
}


怎么样,是不是一目了然?count被定义为static,是因为要保证整个系统只有这一个count。如果你实在不放心,可以把它写成一个单例类。

然后在web.xml中声明这个监听器:
Java代码

1. <listener>
2. <listener-class>
3. org.bromon.test.SessionCount
4. </listener-class>
5. </listener>

<listener>
<listener-class>
org.bromon.test.SessionCount
</listener-class>
</listener>


编写一个测试页面test.jsp,内容是获得count:
Java代码

1. <%
2. int count=org.bromon.test.SessionCount.getCount();
3. out.println(count);
4. %>

<%
int count=org.bromon.test.SessionCount.getCount();
out.println(count);
%>


需要注意的是,这里根本不涉及任何session的操作。重启动App server,试着连接test.jsp,可以看到监听器已经开始工作。

2、 Attribute监听
例如一个站内消息系统,肯定要获得所有登陆者的ID,才有可能互发消息。这就涉及Attribute监听。假设我们写了个用户登陆的模块,用户通过身份验证之后会产生一个session,保存它的相关信息,比如:
Java代码

1. //check.jsp
2. <%
3. String name=request.getParameter(“name”);
4. Name=new String(name.getBytes(“ISO8859-1”));
5. session.setAttribute(“user”,name);
6. %>

//check.jsp
<%
String name=request.getParameter(“name”);
Name=new String(name.getBytes(“ISO8859-1”));
session.setAttribute(“user”,name);
%>


做过jsp的兄弟应该对这段代码再熟悉不过了,下面写个监听器来监听用户登陆,把所有用户的ID保存到一个List当中,这个监听器实作HttpSessionAttributeListener接口:
Java代码

1.
2. package org.bromon.test;
3.
4. import javax.servlet.*;
5. import javax.servlet.http.*;
6. import java.util.*;
7.
8. public class OnlineList implements HttpSessionAttributeListener{
9. private static List list=new ArrayList();
10.
11. public void attributeAdded(HttpSessionBindingEvent se){
12. if( "user ".equals(se.getName())){
13. list.add(se.getValue());
14. }
15. }
16.
17. public void attributeRemoved(HttpSessionBindingEvent se){
18. if( "user ".equals(se.getName())){
19. list.remove(se.getValue());
20. }
21. }
22.
23. public void attributeReplaced(HttpSessionBindingEvent se){}
24.
25. public static List getList(){
26. return(list);
27. }
28. }


package org.bromon.test;

import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;

public class OnlineList implements HttpSessionAttributeListener{
private static List list=new ArrayList();

public void attributeAdded(HttpSessionBindingEvent se){
if( "user ".equals(se.getName())){
list.add(se.getValue());
}
}

public void attributeRemoved(HttpSessionBindingEvent se){
if( "user ".equals(se.getName())){
list.remove(se.getValue());
}
}

public void attributeReplaced(HttpSessionBindingEvent se){}

public static List getList(){
return(list);
}
}



写个简单的jsp来得到用户列表:
Java代码

1.
2. <%
3. java.util.List list=org.bromon.test.OnlineList.getList();
4. out.println( "共有 "+list.size()+ "名用户已登陆: ");
5. for(int I=0;I <lise.size();i++){
6. out.println(list.get(i));
7. }
8. %>


<%
java.util.List list=org.bromon.test.OnlineList.getList();
out.println( "共有 "+list.size()+ "名用户已登陆: ");
for(int I=0;I <lise.size();i++){
out.println(list.get(i));
}
%>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值