Jsp & Servlet 会话控制

作者:guipei
前言
作为j2ee的重要组成部分的jsp和servlet规范中,会话(session)处理占有非常重要的位置。目前,很多资料都非常详细的讲解了会话跟踪如何处理。但是,针对会话控制却很少有人涉及,原本在servlet规范中,servlet提供了httpsessioncontext接口处理会话控制功能,但是,在servlet api 2.1以后,这个功能被取消了,参考原文(as of java(tm) servlet api 2.1 for security reasons, with no replacement. this interface will be removed in a future version of this api.)。

在本文中,作者会给你介绍一种会话控制的方法,采用listener技术,实现httpsessioncontext的功能替换。很多开发人员都会在部分场合方便得使用到这个功能完成某些任务,例如:在线人员信息查看,在线人员控制等等功能。

分析
本文采用实例方式介绍会话控制功能。使用若干jsp页面,和一个java类完成整个功能演示。详见下表:

组件
功能

com.guipei.listener. sessionlistener
监听组件,完成httpsessioncontext的功能

index.jsp
实现用户登陆,创建新的session

logout.jsp
实现用户退出,用户自动删除session

display.jsp
显示用户登陆信息,在用户登陆后自动转入

session.jsp
列出当前所有的session

kill.jsp
杀掉指定的会话,使这个用户连接无效

实现
监听类com.guipei.listener.sessionlistener 实现web application的监听功能,它实现了httpsessionlistener接口,可以监听sessioncreated(httpsessionevent se)和sessiondestroyed(httpsessionevent se) 方法,因此我们可以很容易的在session的创建和销毁事件过程中处理session的控制。

在此类中,我们创建一个静态实例变量hashtable ht,采用hashtable的一个好处是它是线程安全的集合类,无须我们再多做线程处理。采用这个collection类保存我们所要控制的session对象。在监听事件中容易的处理相关任务。

参看全部代码:

页面index.jsp 处理用户登陆,创建新的会话的功能。在完成验证后,跳转到display.jsp页面上。

页面display.jsp用于用户登陆后的显示功能,如果用户没有进行过登陆请求,会自动转发到index.jsp页面,保证用户登陆。

页面logout.jsp用于用户退出登陆,采用主动方式销毁session。

页面session.jsp列出当前会话用户,并提供一个连接到kill.jsp,可以用作销毁指定的会话操作。

页面kill.jsp实现销毁指定会话的功能,接收一个session id参数,从我们保存的session对象集合中取得对应的session对象,调用invalidate方法,销毁对象。

完成以上代码后,还需要在web.xml描述中添加以下元素。使得sessionlistener类可以发挥监听功能。

总结
作者不是很清楚,servlet规范为什么要取消httpsessioncontext接口,尽管它声明了取消的原因,但是我们仍然可以容易的通过httpsessionlistener接口实现这个功能。

希望本文可以提供一个新的方法,替换已经被servlet规范废除的httpsessioncontext接口。让我们可以方便的进行会话操作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值