JavaWeb-会话的持久化:HttpSessionActivationListener

简介: JavaWeb-会话的持久化:HttpSessionActivationListener

要实现会话的持久化,也就是实现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/

image.png

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

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

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

image.png

<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只做为监听类,监听自己是否钝化或是活化。

image.png

使用shutdown.bat关闭tomcat应用:

image.png

目录
相关文章
|
23天前
|
监控 Java 数据管理
java会话跟踪和拦截器过滤器
本文介绍了Web开发中的会话跟踪技术——Cookie与Session,以及过滤器(Filter)和监听器(Listener)的概念和应用。Cookie通过在客户端记录信息来识别用户,而Session则在服务器端保存用户状态。过滤器用于拦截和处理请求及响应,监听器则监控域对象的状态变化。文章详细解释了这些技术的实现方式、应用场景和主要方法,帮助开发者更好地理解和使用这些工具。
38 1
|
3月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
440 37
|
2月前
|
前端开发 Java 应用服务中间件
Javaweb学习
【10月更文挑战第1天】Javaweb学习
33 2
|
2月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
60 5
|
3月前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
3月前
|
安全 Java Android开发
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
JavaWeb解压缩漏洞之ZipSlip与Zip炸弹
116 2
|
2月前
|
SQL Java API
深入探索Java的持久化技术——JPA(Java Persistence API)
【10月更文挑战第10天】深入探索Java的持久化技术——JPA(Java Persistence API)
44 0
|
2月前
|
Java API 数据库
深入探索Java的持久化技术——JPA(Java Persistence API)
【10月更文挑战第10天】深入探索Java的持久化技术——JPA(Java Persistence API)
46 0
|
3月前
|
SQL JSON JavaScript
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
Vue 指令、生命周期、this和$、vue脚手架进行模块化开发/ElementUI框架、综合案例,element商品列表展示增删改查
JavaWeb基础9——VUE,Element&整合Javaweb的商品管理系统
|
12天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####