JavaWeb学习笔记(十三)之session的钝化和活化

JavaWeb学习笔记(十三)之session的钝化和活化,第1张

JavaWeb学习笔记(十三)之session的钝化活化 session的钝化和活化 钝化:内存—>硬盘 活化:硬盘—>内存 session对象的四种状态

监听绑定和解绑:HttpSessionBingListener

1.session.setAttribute(“a”,xxx)
意思是将对象a【绑定】到session中

2.session.removeAttribute(“a”)
将对象a从session中【解绑】

监听session对象的钝化、活化:HttpSessionActivationListener

3.钝化

  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):当对象感知被钝化时调用本方法;

4.活化

  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配置后对所有项目都生效)

代码示例:
//BindingListener.java

public class BeanListener implements Serializable,HttpSessionBindingListener,HttpSessionAttributeListener,HttpSessionActivationListener {
	//准备被钝化、活化的数据
	private int num;
	private String user;

	    public int getNum() {
        return num;
    }

    public void setNum(int num) {
        this.num = num;
    }

    public String getUser() {
        return user;
    }

    public void setUser(String user) {
        this.user = user;
    }

	public BeanListener() {
		// TODO Auto-generated constructor stub
	}

	public void sessionWillPassivate(HttpSessionEvent se) {
		// 监听时刻:即将钝化之前
		System.out.println("session:"+se.getSession().getId()+"将钝化");
	}

	public void sessionDidActivate(HttpSessionEvent se) {
		// 监听时刻:刚刚进行了活化之后
		System.out.println("session:"+se.getSession().getId()+"已活化");
	}

	public void attributeAdded(HttpSessionBindingEvent se) {
		// TODO Auto-generated method stub
		System.out.println("session:"+se.getSession().getId()+"在添加属性");
	}

	public void attributeRemoved(HttpSessionBindingEvent se) {
		// TODO Auto-generated method stub
		System.out.println("session:"+se.getSession().getId()+"在删除属性");
	}

	public void attributeReplaced(HttpSessionBindingEvent se) {
		// TODO Auto-generated method stub
		System.out.println("session:"+se.getSession().getId()+"发生了属性替换");
	}

	public void valueBound(HttpSessionBindingEvent event) {
		// TODO Auto-generated method stub
		System.out.println("session:"+event.getSession().getId()+"event发生了Bound绑定");
	}

	public void valueUnbound(HttpSessionBindingEvent event) {
		// TODO Auto-generated method stub
		System.out.println("session:"+event.getSession().getId()+"event发生了UnBound绑定");
	}

}

代码示例:

活化:在session销毁后,直接像原来的方式进行${sessionScop.name}提取就可以,前提是实现serizable

测试代码:

钝化、活化的本质就是序列化和反序列化

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5438808.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-11
下一篇 2022-12-11

发表评论

登录后才能评论

评论列表(0条)

保存