`
wumin123150
  • 浏览: 9652 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

HttpSessionListener和HttpSessionBindingListener的区别

阅读更多

1. 使用HttpSessionListener

编写一个OnlineUserListener。

package anni;

import java.util.List;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionListener;
import javax.servlet.http.HttpSessionEvent;

public class OnlineUserListener implements HttpSessionListener {

    public void sessionCreated(HttpSessionEvent event) {

    }

    public void sessionDestroyed(HttpSessionEvent event) {
        HttpSession session = event.getSession();
        ServletContext application = session.getServletContext();
        // 取得登录的用户名
        String username = (String) session.getAttribute("username");
        // 从在线列表中删除用户名
        List onlineUserList = (List) application.getAttribute("onlineUserList");
        onlineUserList.remove(username);
        System.out.println(username + "超时退出。");
    }

}

OnlineUserListener实现了HttpSessionListener定义的两个方法:sessionCreated()和 sessionDestroyed()。这两个方法可以监听到当前应用中session的创建和销毁情况。我们这里只用到 sessionDestroyed()在session销毁时进行操作就可以。

从HttpSessionEvent中获得即将销毁的session,得到session中的用户名,并从在线列表中删除。最后一句向console打印一条信息,提示操作成功,这只是为了调试用,正常运行时删除即可。

为了让监听器发挥作用,我们将它添加到web.xml中:

<listener>
    <listener-class>anni.OnlineUserListener</listener-class>
</listener>

以下两种情况下就会发生sessionDestoryed(会话销毁)事件:

  1. 执行session.invalidate()方法时。

    既然LogoutServlet.java中执行session.invalidate()时,会触发sessionDestory()从在线用户 列表中清除当前用户,我们就不必在LogoutServlet.java中对在线列表进行操作了,所以LogoutServlet.java的内容现在是 这样。

    public void doGet(HttpServletRequest request,HttpServletResponse response) {
    
        throws ServletException, IOException {
        // 销毁session
        request.getSession().invalidate();
        // 成功
        response.sendRedirect("index.jsp");
        }
    } 
  2. 如果用户长时间没有访问服务器,超过了会话最大超时时间,服务器就会自动销毁超时的session。

    会话超时时间可以在web.xml中进行设置,为了容易看到超时效果,我们将超时时间设置为最小值。

    <session-config>
        <session-timeout>1</session-timeout>
    </session-config>
    

    时间单位是一分钟,并且只能是整数,如果是零或负数,那么会话就永远不会超时。

对应例子在08-01,为了验证OnlineUserListener是否能正常执行,我们可以登录两个用户,其中一个点击注销,另一个等待一分钟,然后可以在console中看到输出的信息。

470)this.style.width=470" align=center>

2. 使用HttpSessionBindingListener

HttpSessionBindingListener虽然叫做监听器,但使用方法与HttpSessionListener完全不同。我们实际看一下它是如何使用的。

我们的OnlineUserBindingListener实现了HttpSessionBindingListener接口,接口中共定义了两个方法:valueBound()和valueUnbound(),分别对应数据绑定,和取消绑定两个事件。

所谓对session进行数据绑定,就是调用session.setAttribute()把HttpSessionBindingListener保存进session中。我们在LoginServlet.java中进行这一步。

// 把用户名放入在线列表
session.setAttribute("onlineUserBindingListener", new OnlineUserBindingListener(username));

这就是HttpSessionBindingListener和HttpSessionListener之间的最大区别: HttpSessionListener只需要设置到web.xml中就可以监听整个应用中的所有session。 HttpSessionBindingListener必须实例化后放入某一个session中,才可以进行监听。

从监听范围上比较,HttpSessionListener设置一次就可以监听所有session,HttpSessionBindingListener通常都是一对一的。

正是这种区别成就了HttpSessionBindingListener的优势,我们可以让每个listener对应一个username,这样 就不需要每次再去session中读取username,进一步可以将所有操作在线列表的代码都移入listener,更容易维护。

valueBound()方法的代码如下:

public void valueBound(HttpSessionBindingEvent event) {
    HttpSession session = event.getSession();
    ServletContext application = session.getServletContext();
    // 把用户名放入在线列表
    List onlineUserList = (List) application.getAttribute("onlineUserList");
    // 第一次使用前,需要初始化
    if (onlineUserList == null) {
        onlineUserList = new ArrayList();
        application.setAttribute("onlineUserList", onlineUserList);
    }
    onlineUserList.add(this.username);
}

username已经通过构造方法传递给listener,在数据绑定时,可以直接把它放入用户列表。

与之对应的valueUnbound()方法,代码如下:

public void valueUnbound(HttpSessionBindingEvent event) {
    HttpSession session = event.getSession();
    ServletContext application = session.getServletContext();

    // 从在线列表中删除用户名
    List onlineUserList = (List) application.getAttribute("onlineUserList");
    onlineUserList.remove(this.username);

    System.out.println(this.username + "退出。");
}

这里可以直接使用listener的username操作在线列表,不必再去担心session中是否存在username。

valueUnbound的触发条件是以下三种情况:

  1. 执行session.invalidate()时。

  2. session超时,自动销毁时。

  3. 执行session.setAttribute("onlineUserListener", "其他对象");或session.removeAttribute("onlineUserListener");将listener从session中删除时。

因此,只要不将listener从session中删除,就可以监听到session的销毁。

分享到:
评论

相关推荐

    HttpSessionListener 和HttpSessionBindingListener的区别 单点登录

    ### HttpSessionListener 和 HttpSessionBindingListener 的区别 #### 一、概述 在Java Web开发中,`HttpSessionListener`和`HttpSessionBindingListener`都是用于监听HTTP会话生命周期的重要接口。它们分别用于...

    jsp 统计在线人数利用HttpSessionListener、HttpSessionBindingListener

    jsp 统计在线人数实例,是个完整的项目实例,部署即可查看效果! 通过使用:HttpSessionListener、HttpSessionBindingListener来实现. valueBound 方法登录触发。 valueUnbound 方法退出触发。

    HttpSessionBindingListener获取在线用户数(转)

    在Java Web开发中,管理在线用户数量是一项常见的需求。`HttpSessionBindingListener`接口提供了一种优雅的方式来跟踪...结合`HttpSessionListener`和其他Web容器提供的特性,我们可以构建出高效、可靠的用户管理方案。

    Spring+Struts2+ibatis 异地登录 HttpSessionBindingListener

    基于Spring+Struts2+ibatis框架,利用 HttpSessionBindingListener接口进行监听,实现防止异地登录,配有全部代码及sql数据库表

    servlet监听器

    用于监听HttpSession的创建和销毁事件,监听器类需实现javax.servlet.http.HttpSessionListener接口。 HttpSessionListener接口的方法: voidsessionCreated(HttpSessionEventhsce) 通知正在接收的对象,新的...

    在线人数统计

    在这个小型案例中,我们使用了Java Servlet中的`HttpSessionListener`和`HttpSessionBindingListener`接口来实现这一功能。以下是对这两个接口以及整个案例的详细解释: 1. **`HttpSessionListener`接口**: `...

    Servlet技术(事件监听器-在线踢人).zip

    在Java Servlet API中,提供了多种监听器接口,例如HttpSessionListener、HttpSessionAttributeListener和HttpSessionBindingListener,用于监听会话的创建、销毁、属性添加、修改和移除等事件。 在这个特定的例子...

    listener和filter 监听器和过滤器的介绍以及简单使用(csdn)————程序.pdf

    - **第三类**:HttpSessionBindingListener和HttpSessionActivationListener,用于监听HttpSession中的JavaBean状态变化,如钝化、活化、绑定和解除绑定。 【监听器使用示例】 - **ServletContextListener**:在...

    servlet 监听器范例

    例如,`HttpSessionListener`用于监听会话的创建和销毁,`ServletRequestListener`则关注请求的开始和结束。在这个“servlet 监听器范例”中,我们主要关注的是`HttpSessionListener`,因为它是追踪在线用户的关键。...

    Listener监听器1

    * HttpSessionListener:用于监听HttpSession的创建和销毁事件 这些接口都有两个方法:一个是销毁触发方法,一个是创建触发方法。例如,ServletContextListener有contextDestroyed方法和contextInitialized方法。 ...

    Web监听器

    3. **使用示例**:例如,HttpSessionListener可以用于统计当前在线用户数量,每当一个新的会话创建或结束,监听器的sessionCreated和sessionDestroyed方法会被调用。 4. **编程实践**:实现监听器接口需要覆盖指定...

    javaee-Session持久化小结

    例如,可以使用Servlet容器(如Tomcat)的内置Session持久化配置,或者自定义实现`HttpSessionListener`和`HttpSessionBindingListener`来监听Session的创建和销毁事件,进行手动持久化操作。 标签中的"源码"可能...

    java监听器和过滤器详解

    4. **编写监听器**:实现`HttpSessionListener`接口,重写`sessionCreated()`与`sessionDestroyed()`方法,以便在用户登录和注销时更新在线用户列表。 5. **配置监听器**:在`web.xml`中注册监听器。 6. **页面展示*...

    清华ITjsp课件8

    `HttpSessionListener`接口用于监听会话的创建和销毁,这有助于了解系统中活动用户的数量。`sessionCreated`在新会话创建时触发,`sessionDestroyed`在会话过期或显式销毁时触发。此外,`...

    JAVA J2EE 类库文档

    HttpSessionBindingListener HttpSessionContext HttpSessionEvent HttpSessionListener HttpUtils RequestDispatcher Servlet ServletConfig ServletContext ServletContextAttributeEvent ...

    利用session监听器实现一个客户不能再两个客户端登录。

    在Java Web中,我们可以使用HttpSessionListener或者HttpSessionAttributeListener接口来实现这一目标。这里我们将主要关注HttpSessionBindingListener,因为它可以监听到Session中的属性变化。 1. 创建一个实现了...

    JavaWeb开发技术-Listener监听器.pptx

    - **HttpSessionBindingListener** 和 **HttpSessionActivationListener**:这两个接口关注HttpSession中对象的绑定和激活事件,常用于会话持久化和集群环境下的会话管理。 4. **使用监听器的好处** - **解耦合**...

    网页教程《跟姐姐学JSP》

    8.2. 使用HttpSessionBindingListener 9. 封装taglib组件 9.1. 用taglib实现循环 9.2. 关于jstl 10. 综合电子留言板 10.1. 电子留言板用户指南 10.2. 数据库设计 10.3. 功能设计 10.3.1. 用户管理 10.3.2. ...

    Servlet中监听器介绍.doc

    - `HttpSessionListener`接口:用于监听HttpSession的创建和销毁事件。`sessionCreated`方法在新的HttpSession被创建时调用,`sessionDestroyed`方法在HttpSession失效或被显式地销毁时调用。这为跟踪用户会话、...

Global site tag (gtag.js) - Google Analytics