session监听器HttpSessionBindingListener

首先我在网上查了一下session的真正销毁条件:

1调用 session.invalidate();方法

2 session到了设置或者默认的超时时间,自动销毁(关闭浏览器此session还未销毁,只是不能再用了);

明白了上面的两条就可以去研究一下HttpSessionBindingListener这种session监听了。

新建一个类,继承HttpSessionBindingListener,实现了两个方法,分别是:

valueBound()和valueUnbound(),这个类按照通俗的理解就是对session绑定对象(setAttribute)过程的一种监听类型,它不需要配置xml文件,只是将实例化的HttpSessionBindingListener对象setAttribute到session里面就可以对HttpSessionBindingListener对象对象进行监听了,其实也就是对HttpSessionBindingListener对象所对应的session进行监听,还可以记录该session的具体信息(例如会员的登录信息)。

valueBound是在setAttribute时触发

valueUnbound则是在session销毁时触发。^-^(什么时候销毁上文有提到)

做出这样的一个例子:

新建一个继承自HttpSessionBindingListener的类UsersOnlineCountListener

[java] view plain copy

  1. public class UsersOnlineCountListener implements HttpSessionBindingListener {
  2. int uid;
  3. public int getUid() {
  4. return uid;
  5. }
  6. public void setUid(int uid) {
  7. this.uid = uid;
  8. }
  9. public void valueBound(HttpSessionBindingEvent arg0) {
  10. System.out.println(uid+"登录了"+new Date());
  11. }
  12. public void valueUnbound(HttpSessionBindingEvent arg0) {
  13. System.out.println(uid+"下线了"+new Date());
  14. }
  15. }

会员登录成功的时候,代码中加上:

[java] view plain copy

  1. UsersOnlineCountListener uocl = new UsersOnlineCountListener();
  2. uocl.setUid(obj.getUid());
  3. session.setAttribute("uocl", uocl);//这个时候要触发valueBound方法了

控制台输出:

11登录了Mon Sep 20 02:09:37 CST 2010

点击注销的时候,session销毁,触发valueUnbound

控制台输出:

11下线了Mon Sep 20 02:10:22 CST 2010

如果直接关闭浏览器,控制台不会立刻输出"11下线了Mon Sep 20 02:40:13 CST 2010"

大约30分钟后(session的自动销毁时间,可以设定)

控制台输出:

11下线了Mon Sep 20 02:40:13 CST 2010

这里总结下:valueUnbound方法将被以下任一条件触发

a. 执行session.setAttribute("uocl", 非uocl对象) 时。
b. 执行session.removeAttribute("uocl") 时。
c. 执行session.invalidate()时。
d. session超时后。

本文转自:http://blog.csdn.net/lovesea9/article/details/7612017

原文地址:https://www.cnblogs.com/nizuimeiabc1/p/8463560.html

时间: 2024-10-30 05:20:46

session监听器HttpSessionBindingListener的相关文章

Spring的自动装配在session监听器失效

先看代码 package com.oa.listener; import javax.servlet.http.HttpSession; import javax.servlet.http.HttpSessionEvent; import javax.servlet.http.HttpSessionListener; import org.springframework.beans.factory.annotation.Autowired; import com.oa.service.Syste

Spring注解无法注入Session监听器解决办法

public class DefaultSessionListener implements HttpSessionListener { public void sessionCreated(HttpSessionEvent arg0) { ApplicationContext ctx = WebApplicationContextUtils.getRequiredWebApplicationContext(arg0.getSession().getServletContext());   IM

JavaWeb学习笔记八 监听器

监听器Listener jservlet规范包括三个技术点:servlet :listener :filter:监听器就是监听某个对象的的状态变化的组件.监听器的相关概念事件源: 被监听的对象(三个域对象 request,session,servletContext) 监听器:监听事件源对象, 事件源对象的状态的变化都会触发监听器 . 注册监听器:将监听器与事件源进行绑定. 响应行为:监听器监听到事件源的状态变化时,所涉及的功能代码(程序员编写代码) 按照被监听的对象划分:ServletRequ

用HttpSessionListener与HttpSessionBindingListener实现在线人数统计

在线人数统计方面的实现,最初我的想法是,管理session,如果session销毁了就减少,如果登陆用户了就新增一个,但是如果是用户非法退出,如:未注销,关闭浏览器等,这个用户的session是管理不到的,最后决定用HttpSessionListener接口或HttpSessionBindingListener接口来实现,通过监听session的新建和销毁来控制,详细如下. 先添加登陆的页面index.jsp <%@ page contentType="text/html;charset=

在Java Web程序中使用监听器可以通过以下两种方法

之前学习了很多涉及servlet的内容,本小结我们说一下监听器,说起监听器,编过桌面程序和手机App的都不陌生,常见的套路都是拖一个控件,然后给它绑定一个监听器,即可以对该对象的事件进行监听以便发生响应,从本质上来说这些都是观察者模式的具体实现,在web程序中的监听器也不例外.在Java Web程序中使用监听器可以通过以下两种方法:通过注解@WebListener来标识一个自定义的监听器:[java] view plain copy@WebListener public class Custom

JavaWeb-18 (JDBC之分页与监听器listener)

JavaWeb-18 JDBC之分页与监听器listener 一.分页 1.分页概述:分页的结果就是要让指定的记录加载到内存 2.原因: 1.人的习惯 2.内存的限度(核心问题) 3.屏幕的限度 3.如何分页: 不同的环境方式不一样 3.1.数据库层面: select * from acount limit startIndex,size;//只是针对MySql而言(startIndex从0开始,size:共查询多少条记录) select * from acount limit 0,3; 第一页

Java Web学习总结(13)Listener监听器

一,监听器介绍 监听器是一个专门用于对其他对象身上发生的事件或状态改变进行监听和相应处理的对象,当被监视的对象发生情况时,立即采取相应的行动.监听器其实就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上述事件后,监听器某个方法立即被执行. 监听器的相关概念: 事件源 被监听的对象 监听器 监听事件源对象,事件源对象的状态的变化都会触发监听器 注册监听器 将监听器与事件源进行绑定. 响应行为 监听器监听到事件源的状态变化时 所涉及

Lisener 监听器

Listener时Servlet的监听器监听客户端的请求和服务器的操作通过实现Listener接口的类可以在监听到特定事件后激发一些操作HttpSessionBindingListener监听器HttpSessionBindingListener当一个实现了该接口的对象捆绑到session中或从session中被解放的时候启用此监听session创建和销毁时分别触发valueBound()和ValueUnbound()方法HttpSessionBindingListener监听器实现在线用户的统

利用session+application+cookie 实现单态登陆,且解决浏览器意外关闭的问题

最近在帮朋友做一个购物网站,里面涉及到了登陆的问题.其中包括后台管理员的登陆和用户的登陆. 在这个网站中,设计了后台管理员单态登陆,即一个账号只能有一个登陆实例.很容易想到的就是用application实现,在application中放置一个hashmap,储存登陆的管理员信息.同时为了实现登陆超时,也在session中存放登陆对象,通过设置session的listener监控session的消亡,移除application中的对象.那么问题来了,如果用户因为断电或者任性,非法关闭了浏览器,再打