监听绑定和解绑: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
测试代码:
钝化、活化的本质就是序列化和反序列化
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)