HttpSessionBindingListener实现与应用
2004-11-06 20:18
525 查看
HttpSessionBindingListener接口有两方需要实现的方法:
public synchronized void valueBound(HttpSessionBindingEvent httpsessionbindingevent)
public synchronized void valueUnbound(HttpSessionBindingEvent httpsessionbindingevent)
Session创建的时候Servlet容器将会调用valueBound方法;Session删除的时候则调用valueUnbound方法.
具体应用可以跟踪每个在登录用户,记录相关的信息,以及在其超时的时候及时的删除相关的信息.
实例代码如下:
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
....
....
public synchronized void valueBound(HttpSessionBindingEvent httpsessionbindingevent){
//检查是否有效
if(!Valid()) return;
//检查信息是否已经存在.不存在则添加.
if(Info.online.containsKey(m_userId))
{
//记录日志信息
log.info("initial user context....");
UserOnlineStruct UOS = (UserOnlineStruct)Info.online.get(m_userId);
UOS.loginIp = uos.loginIp;
UOS.loginTime = uos.loginTime;
UOS.sessionId = uos.sessionId;
}
else{
Info.online.put(m_userId, uos);
}
}
public synchronized void valueUnbound(HttpSessionBindingEvent httpsessionbindingevent){
//检查是否有效
if(!Valid()) return;
//删除用户相关信息
//记录日志信息
log.info("destory user context....");
Info.online.remove(m_userId);
}
--------------------------------
如果你没有使用log4j的话,你可以把log.info()改为System.out.println()会得到同样的结果.
如果你想配置log4j,请点击日志记录的使用方法
如果你还有什么问题,请与我联系:webmaster@bcxy.com
作者Blog:http://blog.csdn.net/ezerg/
相关文章
一个电子商务网站的设计及开发环境配置文档 |
集成测试Strtus+Spring+Hibernate |
Hibernate的批量删除的效率分析 |
JAVA中用动态代理类实现记忆功能 |
配置JBoss 4 JDBC连接JDBC |
相关文章推荐
- ATL实现Connection Point的一种简单的方法
- OpenOffice,好用的开源办公软件
- Hibernate文章征集
- Jakarta Commons logging package
- Hibernate Tool & Files
- 在做控件的存取控制时碰到的问题,请教各位!
- Java日记(1) 一. 认识Java
- 一些好用的Eclipse 3.0插件
- Ant应用(3)
- servlet生命周期
- log4j的配制及测试程序
- servlet的2种重定向方法
- tiles和struts初步应用
- GSFL:一种网格服务的工作流架构(二)
- 在Websphere中开发Ejb需要注意的环节(1)
- ejb3.0改进给我带来的一点感受
- 关于log42j引发的日志文件权限的问题
- Log4j自定义生成文件的名称
- Log4j多文件保存不同等级日志信息
- ovftool自动部署/导出ova/ovf模板