细说Session的钝化和活化及Session的监听器

1.Session的监听器
HttpSessionBindingListener:当某个类实现了该接口后,可以感知本类对象添加到session中,以及感知从session中移除。例如让User类实现HttpSessionBindingListener接口,那么当把Person对象添加到session中,或者把Person对象从session中移除时会调用下面两个方法:
public void valueBound(HttpSessionBindingEvent event):当把监听器对象添加到session中会调用监听器对象的本方法;
public void valueUnbound(HttpSessionBindingEvent event):当把监听器对象从session中移除时会调用监听器对象的本方法;

这里要注意,HttpSessionBindingListener监听器的使用与前面介绍的都不相同,当该监听器对象添加到session中,或把该监听器对象从session移除时会调用监听器中的方法。并且无需在web.xml文件中部署这个监听器。

package ListenerTest;

import javax.servlet.http.HttpSessionBindingEvent;
import javax.servlet.http.HttpSessionBindingListener;

public class User implements HttpSessionBindingListener{
	private String name;
	private String password;
	@Override
	public void valueBound(HttpSessionBindingEvent arg0) {
		System.out.println("我被加到session域中了");	
	}
	@Override
	public void valueUnbound(HttpSessionBindingEvent arg0) {
		System.out.println("我从session域中移除了");
		
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
}

依次在jsp页面写下列代码 并在浏览器访问之

  <%
  ListenerTest.User user = new User();
  session.setAttribute("user", user);
  %>
   <%session.removeAttribute("user"); %>

控制台输出

我被加到session域中了
我从session域中移除了

2.Session的钝化和活化
HttpSessionActivationListener:Tomcat会在session从时间不被使用时钝化session对象,所谓钝化session,就是把session通过序列化的方式保存到硬盘文件中。当用户再使用session时,Tomcat还会把钝化的对象再活化session,所谓活化就是把硬盘文件中的session在反序列化回内存。当session被Tomcat钝化时,session中存储的对象也被纯化,当session被活化时,也会把session中存储的对象活化。如果某个类实现了HttpSessionActiveationListener接口后,当对象随着session被钝化和活化时,下面两个方法就会被调用:
public void sessionWillPassivate(HttpSessionEvent se):当对象感知被活化时调用本方法;
public void sessionDidActivate(HttpSessionEvent se):当对象感知被钝化时调用本方法;

HttpSessionActivationListener监听器与HttpSessionBindingListener监听器相似,都是感知型的监听器,例如让Person类实现了HttpSessionActivationListener监听器接口,并把Person对象添加到了session中后,当Tomcat钝化session时,同时也会钝化session中的Person对象,这时Person对象就会感知到自己被钝化了,其实就是调用Person对象的sessionWillPassivate()方法。当用户再次使用session时,Tomcat会活化session,这时Person会感知到自己被活化,其实就是调用Person对象的sessionDidActivate()方法。
注意,因为钝化和活化session,其实就是使用序列化和反序列化技术把session从内存保存到硬盘,和把session从硬盘加载到内存。这说明如果Person类没有实现Serializable接口,那么当session钝化时就不会钝化Person,而是把Person从session中移除再钝化!这也说明session活化后,session中就不在有Person对象了。

Session的钝化机制:就是把内存中的session信息保存到硬盘中
Session的活化机制:下一次进行调用的时候把钝化的session域中信息唤醒
可以想象,当许多客户不活动的session信息都存在内存中->大量消耗内存资源。
Session的钝化机制可以解决:在当前项目的config.xml中进行配置 或也可以在Tomcat的config.xml进行配置(在Tomcat配置后对所有项目都生效)


	
		
	

默认会创建一个mysession的文件夹其中存放的就是钝化后的session数据 过一分钟把不活动的Session进行钝化

但发现过了一分钟后session域中保存的东西不见了,其实是User类没有实现序列化接口,没有实现序列化接口的对象不能写入到硬盘中,自然User对象的数据就丢失了改进的User类如下:

public class User implements HttpSessionBindingListener, HttpSessionActivationListener,Serializable{
	private String name;
	private String password;
	@Override
	public void valueBound(HttpSessionBindingEvent arg0) {
		System.out.println("我被加到session域中了");	
	}
	@Override
	public void valueUnbound(HttpSessionBindingEvent arg0) {
		System.out.println("我从session域中移除了");
		
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
	@Override
	public void sessionDidActivate(HttpSessionEvent arg0) {
	System.out.println("我被活化了");
		
	}
	@Override
	public void sessionWillPassivate(HttpSessionEvent arg0) {
	System.out.println("我被顿化了");
		
	}
}

你可能感兴趣的:(java从菜鸟到进阶)