session的活化与钝化就是当用户访问时网站异常,不能丢掉session,所有也必须采用文件存储;和之前那个统计网站访问量一样的原理。
class Person implements必须实现这两个接口,实现session活化和钝化的要求
活化:从硬盘上读取到内存中
纯化:从内存中写到硬盘上
HttpSessionActivationListener
实现此接口的JavaBean,可以感知自己被活化(从硬盘到内存)和钝化(从内存到硬盘)的过程。
如果需要同时保存Session中的JavaBean则JavaBean也要实现Serializable序列化接口。
实现此接口的JavaBean与HttpSessionBindingListener一样,不必配置到web.xml中。
importjava.io.Serializable;importjavax.servlet.http.HttpSessionActivationListener;importjavax.servlet.http.HttpSessionEvent;public class Person implementsHttpSessionActivationListener,Serializable{private static final long serialVersionUID = 1L;privateString name;publicPerson(String name) {this.name =name;
}
@Overridepublic voidsessionWillPassivate(HttpSessionEvent se) {
System.out.println("一个Person对象保存到硬盘了...");
}
@Overridepublic voidsessionDidActivate(HttpSessionEvent se) {
System.out.println("一个Person对象从硬盘读取出来了...");
}
@OverridepublicString toString() {return "Person [name=" + name + "]";
}
}
这个实现之后都不算什么,还需要配置文件。
配置文件可以写在tomcat的目录里面conf---》server.xml里面配置,但是里面配置会修改平台,
所以不建议使用。另一种方法:我们在conf----》Catalina------》localhost------》自定义一个xml文件,里面内容:
这样就可以实现session的活化了。
自己总结:
服务器重启用户session信息保存和恢复(服务器维护需要)
httpsessionActivationlistener
活化(sessiondidactivate)和钝化sessionWillpassivate
public class person implements httpsessionactivationlistener,serviliziable(可序列化,永久存储){
活化和钝化方法《主要的还是xml文件的配置》
}
WEB中监听者的类型:ServletContextListener(最大的)
HttpSessionListener(session创建能访问,销毁)(onlineweb)
活化和钝化需要配置tomcat服务器 (1,servce.xml---2,work catalina 自定义.xml文件)
配置路径---D:\javaSoft\apache-tomcat-7.0.30\conf\Catalina\localhost 需要写一个xml文件,
让服务器启动的时候读取或者配置server.xml(
自定义xml文件:(不用发布)sess.xml 老师写的
自定义xml文件结束
直接访问 8080/sess.xml直接访问
session需要活化或者钝化,主要是配置一下 sess.xml文件