JavaWeb-会话的持久化:HttpSessionActivationListener

转载请注明出处: http://blog.csdn.net/qq_26525215

本文源自大学之旅_谙忆的博客

要实现会话的持久化,也就是实现HttpSessionActivationListener接口。

实现此接口的JavaBean,可以感知自己被活化(从硬盘到内存)和钝化(从内存到硬盘)的过程。

如果需要同时保存Session中的JavaBean。

则JavaBean也要实现Serializable序列化接口。

实现此接口的JavaBean与HttpSessionBindingListener一样,不必配置到web.xml中。必须配置到Tomcat服务器中!

其实就是在用户访问的时候,假如服务器突然关闭了,这个时候,用户的session就不存在了,假如是购物网站,也就相当于,用户好不容易选好的物品,刚刚添加到购物车,结果,因为服务器的突然关闭一下,什么都没了,这样很不好,于是我们就需要实现会话的持久化。

可以让我们在重新启动服务器之后用户的session还在服务器中存在!

即用户session的东西还全部在。

因为我们服务器在关闭的时候把用户的session存储到硬盘了(钝化),在重新启动服务器之后,我们又从硬盘中恢复到内存中!(注意,只要用户还没关闭浏览器,那个session会一直存在用户的客户端的)

然后启动后,用户的信息就不会丢失!

要实现此功能,必须要先配置以下信息:

第一步:书写一个JavaBean,并实现HttpSessionActivationListener接口如下:

package cn.hncu.domain;

import java.io.Serializable;

import javax.servlet.http.HttpSessionActivationListener;
import javax.servlet.http.HttpSessionEvent;

public class Person implements Serializable, HttpSessionActivationListener {
    private String name;

    public Person(String name) {
        super();
        this.name = name;
    }

    @Override
    public void sessionWillPassivate(HttpSessionEvent se) {
        System.out.println(this + "保存到硬盘了...");
    }

    @Override
    public void sessionDidActivate(HttpSessionEvent se) {
        System.out.println(this + "从硬盘读取并活化了...");
    }

    @Override
    public String toString() {
        return "Perosn [name=" + name + "]---"+super.toString();
    }

}

第二步:JSP页面,判断是否存在Person,如果没有将Person放到Session中:(这一步只是为了演示出效果而加的,实际中不用)

<%@page import="java.text.SimpleDateFormat"%>
<%@ page language="java" import="java.util.*, cn.hncu.domain.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  </head>

  <body>
    <h2>演示session钝化与活化技术</h2>

    <%
       if(session.getAttribute("p")==null){
           Person p = new Person(""+ (new Random()).nextInt(100) );
           session.setAttribute("p", p);
       }
       System.out.println(session.getId()+"---"+ session.getAttribute("p") );
       Date d = new Date( session.getCreationTime() );
       System.out.println( new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(d) );
    %>
  </body>
</html>

第三步:配置Tomcat的Server.xml文件或是将配置好的xml发布文件放到CATALIINA_HOME\conf\Catalina\localhost目录下:

一个小知识点:

此xml名字可以随便取,访问的时候是通过该xml的名字去访问的,不要用项目名了。

例如取名为aa.xml,则访问地址为:http://localhost:8080/aa/

假如取名为aa.xml然后用项目名http://localhost:8080/sessionActivationWeb/去访问了,会出现session钝化的时候,无法在e:/a目录下找到。但是活化没有受影响!!!

通过http://localhost:8080/aa/ 去访问就可以在e:/a目录下找到

建议,将xml名字取为:x项目名.xml,这样就可以直接通过http://localhost:8080/项目名 访问,这样session也可以存储到指定路径了!

<Context path="/sessionActivationWeb"    docBase="E:/MyEclipse10_workspace/sessionActivationWeb/WebRoot">
<Manager className="org.apache.catalina.session.PersistentManager"
  saveOnRestart="true">
  <Store className="org.apache.catalina.session.FileStore"
         directory="e:/a"> </Store>
</Manager>
</Context>

directory=”e:/a”

配置的是在服务器关闭后,内存中session存储的路径。

指Session文件保存的目录。

Context path=”/sessionActivationWeb”

sessionActivationWeb是项目名称!

docBase=”E:/MyEclipse10_workspace/sessionActivationWeb/WebRoot”

E:/MyEclipse10_workspace/sessionActivationWeb/WebRoot

为项目下的WebRoot路径

第四步:测试

1:多次开启新的浏览器窗口,并记录SESSIONID。

2:使用shutdown.bat关闭tomcat应用。

3:观察指定的目录下是否存在*.session文件。

4:再次重新启动tomcat,并使用http://localhost:8080/project;jsessionid=xxxxx指定sessionid的方式访问服务器。

(不关闭浏览器也行,再次访问就不要加jsessionid了)

5:观察是否为关闭tomcat之前的同一个Session。

6:一般情况下,PersistentManager持久化Session与Cookie共同使用。

7:HttpSessionActivationListener只做为监听类,监听自己是否钝化或是活化。

使用shutdown.bat关闭tomcat应用:

转载请注明出处: http://blog.csdn.net/qq_26525215

本文源自大学之旅_谙忆的博客

时间: 2024-11-07 16:34:09

JavaWeb-会话的持久化:HttpSessionActivationListener的相关文章

JavaWeb会话跟踪

cookie和session是常用的会话跟踪技术 cookie机制 1.web应用程序是使用HTTP协议传输数据的,HTTP协议是无状态的协议,一旦数据交换完毕就会关闭链接.Cookie可以弥补HTTP协议无状态的不足. 位于:javax.servlet.http.Cookie 2.Cookie具有不可跨域名性.Cookie的管理是浏览器,浏览器判断一个网站是否能操作另一个网站的Cookie的依据是域名.例:images.baidu.com与www.baidu.com不是同一个域名,cookie

tomcat会话之持久化会话管理器

前面提到的标准会话管理器已经提供了基础的会话管理功能,但在持久化方面做得还是不够,或者说在某些情景下无法满足要求,例如把会话以文件或数据库形式存储到存储介质中,这些都是标准会话管理器无法做到的,于是另外一种会话管理器被设计出来--持久化会话管理器. 在分析持久化会话管理器之前不妨先了解另外一个抽象概念会话存储设备Store,引入这个概念是为了更清晰方便地实现各种会话存储方式.作为存储设备最重要的操作无非就是读写操作,读即是将会话从存储设备加载到内存中,而写则将会话写入存储设备中,所以定义了两个重

JavaWeb——会话技术Cookie &amp; Session

会话技术 因为Http协议是无状态的,也就是说每个客户访问服务器端资源时,服务器并不知道该客户端是谁,所以需要会话技术识别客户端的状态.会话技术是帮助服务器记住客户端状态(区分不同的客户端) 从打开一个浏览器访问某个站点,到关闭这个浏览器的整个过程,成为一次会话.会话技术就是记录这次会话中客户端的状态与数据的.会话技术分为Cookie和Session: Cookie:数据存储在客户端本地,减少服务器端的存储的压力,安全性不好,客户端 可以清除cookie Session:将数据存储到服务器端,安

JavaWeb会话管理:(1)Cookie

会话技术 序号 名称 数据存放位置 1 Cookie技术 会话数据保存在浏览器客户端. 2 Session技术 会话数据保存在服务器端. 1.Cookie技术 1.1.特点 Cookie技术:会话数据保存在浏览器客户端. 1.2.Cookie技术核心 Cookie类:用于存储会话数据. Cookie核心API 序号 类别 API 1 构造Cookie对象 Cookie(String name, String value) 2 设置cookie void setPath(String uri)  

JavaWeb会话管理:(2)Session

会话技术 序号 名称 数据存放位置 1 Cookie技术 会话数据保存在浏览器客户端. 2 Session技术 会话数据保存在服务器端. 2.Session技术 2.1.引入 Cookie的局限: 1)Cookie只能存字符串类型.不能保存对象 2)只能存非中文. 3)1个Cookie的容量不超过4KB. 如果要保存非字符串,超过4kb内容,只能使用session技术!!! Session特点:会话数据保存在服务器端.(内存中) 1.2.Session技术核心 HttpSession类:用于保存

第十章 会话管理——《跟我学Shiro》

Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如web容器tomcat),不管JavaSE还是JavaEE环境都可以使用,提供了会话管理.会话事件监听.会话存储/持久化.容器无关的集群.失效/过期支持.对Web的透明支持.SSO单点登录的支持等特性.即直接使用Shiro的会话管理可以直接替换如Web容器的会话管理. 会话 所谓会话,即用户访问应用时保持的连接关系,在多次交互中应用能够识别出当前访问的用户是谁,且可以在多次交互中保存一些数据.如访问一些网站时登录成功后,网站可以记住用

shiro会话

Shiro提供了完整的企业级会话管理功能,不依赖于底层容器(如web容器tomcat),不管JavaSE还是JavaEE环境都可以使用,提供了会话管理.会话事件监听.会话存储/持久化.容器无关的集群.失效/过期支持.对Web的透明支持.SSO单点登录的支持等特性.即直接使用Shiro的会话管理可以直接替换如Web容器的会话管理. 会话 所谓会话,即用户访问应用时保持的连接关系,在多次交互中应用能够识别出当前访问的用户是谁,且可以在多次交互中保存一些数据.如访问一些网站时登录成功后,网站可以记住用

使用SpringSession管理分布式系统的会话Session

在我方供应链项目分布式部署的环境下,需要在统一网关服务中管理访问的Session,即无论访问请求路由到哪一个网关服务环境,使用的都是相同的HttpSession,这样就保证了在用户登录之后,能够使用统一的Session来处理鉴权和其他逻辑,这对于分布式系统的用户会话管理是必要的.为了能够达到这个目的,我们引入了SpringSession. SpringSession是什么 SpringSession是Spring框架大集合下的一个子组件,使用Redis来备份Web服务访问生成的(被加工过的)Ht

shiro框架学习-9-shiroSession

1.什么是会话session : 用户和程序直接的链接,程序可以根据session识别到哪个用户,和javaweb中的session类似 2. 什么是会话管理器SessionManager : 会话管理器管理所有subject的所有操作,是shiro的核心组件,它是一个接口,定义如下: public interface SessionManager { // 开启一个session Session start(SessionContext var1); // 根据指定的key获取session