JavaWeb笔记——三大组件之监听器
2015-08-25 16:20
429 查看
1 JavaWeb监听器概述
在JavaWeb被监听的事件源为:ServletContext、HttpSession、ServletRequest,即三大域对象。
l 监听域对象“创建”与“销毁”的监听器;
l 监听域对象“操作域属性”的监听器;
l 监听HttpSession的监听器(较少用,了解就行)。
三大域对象监听器创建方式为自定义类实现监听器接口,然后在web.xml进行配置,配置实例如下:
<listener>
<listener-class>cn.itcast.listener.MyServletContextListener</listener-class>
</listener>
========================================
2 创建与销毁监听器
创建与销毁监听器一共有三个:
l ServletContextListener:Tomcat启动和关闭时调用下面两个方法
* public void contextInitialized(ServletContextEvent evt):ServletContext对象被创建后调用;
* public void contextDestroyed(ServletContextEvent evt):ServletContext对象被销毁前调用;
l HttpSessionListener:开始会话和结束会话时调用下面两个方法
* public void sessionCreated(HttpSessionEvent evt):HttpSession对象被创建后调用;
* public void sessionDestroyed(HttpSessionEvent evt):HttpSession对象被销毁前调用;
l ServletRequestListener:开始请求和结束请求时调用下面两个方法
* public void requestInitiallized(ServletRequestEvent evt):ServletRequest对象被创建后调用;
* public void requestDestroyed(ServletRequestEvent evt):ServletRequest对象被销毁前调用。
========================================
3 操作域属性的监听器
当对域属性进行增、删、改时,执行的监听器一共有三个:
l ServletContextAttributeListener:在ServletContext域进行增、删、改属性时调用下面方法。
* public void attributeAdded(ServletContextAttributeEvent evt)
* public void attributeRemoved(ServletContextAttributeEvent evt)
* public void attributeReplaced(ServletContextAttributeEvent evt)
l HttpSessionAttributeListener:在HttpSession域进行增、删、改属性时调用下面方法
* public void attributeAdded(HttpSessionBindingEvent evt)
* public void attributeRemoved (HttpSessionBindingEvent evt)
* public void attributeReplaced (HttpSessionBindingEvent evt)
l ServletRequestAttributeListener:在ServletRequest域进行增、删、改属性时调用下面方法
* public void attributeAdded(ServletRequestAttributeEvent evt)
* public void attributeRemoved (ServletRequestAttributeEvent evt)
* public void attributeReplaced (ServletRequestAttributeEvent evt)
=======================================
4 HttpSession的监听器(较少用,了解就行了)
还有两个与HttpSession相关的特殊的监听器,这两个监听器的特点如下:
l 不用在web.xml文件中部署;
l 这两个监听器不是给session添加,而是给Bean添加。即让Bean类实现监听器接口,然后再把Bean对象添加到session域中。
下面对这两个监听器介绍一下:
----------------------------------------------------------
1、HttpSessionBindingListener:当某个类实现了该接口后,可以感知本类对象添加到session中,以及感知从session中移除。例如让Person类实现HttpSessionBindingListener接口,那么当把Person对象添加到session中,或者把Person对象从session中移除时会调用下面两个方法:
* public void valueBound(HttpSessionBindingEvent event):当把监听器对象添加到session中会调用监听器对象的本方法;
* public void valueUnbound(HttpSessionBindingEvent event):当把监听器对象从session中移除时会调用监听器对象的本方法;
这里要注意,HttpSessionBindingListener监听器的使用与前面介绍的都不相同,当该监听器对象添加到session中,或把该监听器对象从session移除时会调用监听器中的方法。并且无需在web.xml文件中部署这个监听器。
示例步骤:
l 编写Person类,让其实现HttpSessionBindingListener监听器接口;
l 编写Servlet类,一个方法向session中添加Person对象,另一个从session中移除Person对象;
l 在index.jsp中给出两个超链接,分别访问Servlet中的两个方法。
Pseron.java
ListenerServlet.java
index.jsp
----------------------------------------------------------
2、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对象了。
示例步骤:
l 先不管HttpSessionActivationListener监听器接口,先来配置Tomcat钝化session的参数,把下面配置文件放到tomcat\conf\catalina\localhost目录下!文件名称为项目名称。
访问项目的index.jsp页面,这会使Tomcat创建Session对象,然后等待一分钟后,查看Tomcat\work\Catalina\localhost\listener\mysession目录下是否会产生文件,如果产生了,说明钝化session的配置成功了,可以开始下一步了。
l 创建Person类,让Person类实现HttpSessionActivationListener和Serializable接口:
Person.java
l 与上例一样,编写Servlet,提供两个方法:一个向session中添加Person对象,另一个从session中移除Person对象:
Person.java
l 在index.jsp页面中给出访问addPerson()和removePerson()的方法:
l 打开index.jsp页面,这时Tomcat会创建session,必须在1分钟之前点击addPerson链接,这能保证在session被钝化之前把Person对象添加到session中;
l 等待一分钟,这时session会被钝化,也就会调用Person的sessionWillPassivate();
l 刷新一下index.jsp页面,这会使session活化,会调用Person的sessionDidActivate()方法。
在JavaWeb被监听的事件源为:ServletContext、HttpSession、ServletRequest,即三大域对象。
l 监听域对象“创建”与“销毁”的监听器;
l 监听域对象“操作域属性”的监听器;
l 监听HttpSession的监听器(较少用,了解就行)。
三大域对象监听器创建方式为自定义类实现监听器接口,然后在web.xml进行配置,配置实例如下:
<listener>
<listener-class>cn.itcast.listener.MyServletContextListener</listener-class>
</listener>
========================================
2 创建与销毁监听器
创建与销毁监听器一共有三个:
l ServletContextListener:Tomcat启动和关闭时调用下面两个方法
* public void contextInitialized(ServletContextEvent evt):ServletContext对象被创建后调用;
* public void contextDestroyed(ServletContextEvent evt):ServletContext对象被销毁前调用;
l HttpSessionListener:开始会话和结束会话时调用下面两个方法
* public void sessionCreated(HttpSessionEvent evt):HttpSession对象被创建后调用;
* public void sessionDestroyed(HttpSessionEvent evt):HttpSession对象被销毁前调用;
l ServletRequestListener:开始请求和结束请求时调用下面两个方法
* public void requestInitiallized(ServletRequestEvent evt):ServletRequest对象被创建后调用;
* public void requestDestroyed(ServletRequestEvent evt):ServletRequest对象被销毁前调用。
========================================
3 操作域属性的监听器
当对域属性进行增、删、改时,执行的监听器一共有三个:
l ServletContextAttributeListener:在ServletContext域进行增、删、改属性时调用下面方法。
* public void attributeAdded(ServletContextAttributeEvent evt)
* public void attributeRemoved(ServletContextAttributeEvent evt)
* public void attributeReplaced(ServletContextAttributeEvent evt)
l HttpSessionAttributeListener:在HttpSession域进行增、删、改属性时调用下面方法
* public void attributeAdded(HttpSessionBindingEvent evt)
* public void attributeRemoved (HttpSessionBindingEvent evt)
* public void attributeReplaced (HttpSessionBindingEvent evt)
l ServletRequestAttributeListener:在ServletRequest域进行增、删、改属性时调用下面方法
* public void attributeAdded(ServletRequestAttributeEvent evt)
* public void attributeRemoved (ServletRequestAttributeEvent evt)
* public void attributeReplaced (ServletRequestAttributeEvent evt)
=======================================
4 HttpSession的监听器(较少用,了解就行了)
还有两个与HttpSession相关的特殊的监听器,这两个监听器的特点如下:
l 不用在web.xml文件中部署;
l 这两个监听器不是给session添加,而是给Bean添加。即让Bean类实现监听器接口,然后再把Bean对象添加到session域中。
下面对这两个监听器介绍一下:
----------------------------------------------------------
1、HttpSessionBindingListener:当某个类实现了该接口后,可以感知本类对象添加到session中,以及感知从session中移除。例如让Person类实现HttpSessionBindingListener接口,那么当把Person对象添加到session中,或者把Person对象从session中移除时会调用下面两个方法:
* public void valueBound(HttpSessionBindingEvent event):当把监听器对象添加到session中会调用监听器对象的本方法;
* public void valueUnbound(HttpSessionBindingEvent event):当把监听器对象从session中移除时会调用监听器对象的本方法;
这里要注意,HttpSessionBindingListener监听器的使用与前面介绍的都不相同,当该监听器对象添加到session中,或把该监听器对象从session移除时会调用监听器中的方法。并且无需在web.xml文件中部署这个监听器。
示例步骤:
l 编写Person类,让其实现HttpSessionBindingListener监听器接口;
l 编写Servlet类,一个方法向session中添加Person对象,另一个从session中移除Person对象;
l 在index.jsp中给出两个超链接,分别访问Servlet中的两个方法。
Pseron.java
public class Person implements HttpSessionBindingListener { private String name; private int age; private String sex; public Person(String name, int age, String sex) { super(); this.name = name; this.age = age; this.sex = sex; } public Person() { super(); } public String toString() { return "Person [name=" + name + ", age=" + age + ", sex=" + sex + "]"; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public void valueBound(HttpSessionBindingEvent evt) { System.out.println("把Person对象存放到session中:" + evt.getValue()); } public void valueUnbound(HttpSessionBindingEvent evt) { System.out.println("从session中移除Pseron对象:" + evt.getValue()); } } |
public class ListenerServlet extends BaseServlet { public String addPerson (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { Person p = new Person("pwc", 18, "male"); request.getSession().setAttribute("person", p); return "/index.jsp"; } public String removePerson (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.getSession().removeAttribute("person"); return "/index.jsp"; } |
<body> <a href="<c:url value='/ListenerServlet?method=addPerson'/>">addPerson</a> <br/> <a href="<c:url value='/ListenerServlet?method=removePerson'/>">removePerson</a> <br/> </body> |
2、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对象了。
示例步骤:
l 先不管HttpSessionActivationListener监听器接口,先来配置Tomcat钝化session的参数,把下面配置文件放到tomcat\conf\catalina\localhost目录下!文件名称为项目名称。
<Context> <Manager className="org.apache.catalina.session.PersistentManager"maxIdleSwap="1" > <Store className="org.apache.catalina.session.FileStore" directory="mysession" /> </Manager> </Context> |
l 创建Person类,让Person类实现HttpSessionActivationListener和Serializable接口:
Person.java
public class Person implements HttpSessionActivationListener, Serializable { private String name; private int age; private String sex; public Person(String name, int age, String sex) { super(); this.name = name; this.age = age; this.sex = sex; } public Person() { super(); } public String toString() { return "Person [name=" + name + ", age=" + age + ", sex=" + sex + "]"; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public void sessionDidActivate(HttpSessionEvent evt) { System.out.println("session已经活化"); } public void sessionWillPassivate(HttpSessionEvent evt) { System.out.println("session被钝化了!"); } } |
Person.java
public class ListenerServlet extends BaseServlet { public String addPerson (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { Person p = new Person("pwc", 18, "male"); request.getSession().setAttribute("person", p); return "/index.jsp"; } public String removePerson (HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.getSession().removeAttribute("person"); return "/index.jsp"; } } |
<body> <a href="<c:url value='/ListenerServlet?method=addPerson'/>">addPerson</a> <br/> <a href="<c:url value='/ListenerServlet?method=removePerson'/>">removePerson</a> <br/> </body> |
l 等待一分钟,这时session会被钝化,也就会调用Person的sessionWillPassivate();
l 刷新一下index.jsp页面,这会使session活化,会调用Person的sessionDidActivate()方法。
相关文章推荐
- Java For循环效率试验
- struts1.x完整实例
- java中只有值传递,没有引用传递
- Eclipse 加速优化
- java interface有多个implement的情况下,@Inject调用实现类的选择
- java中Double类型的运算精度丢失的问题 (小数点多出99999999999999)
- Java线性查找
- Java Web学习路线
- Java: System.exit() 与安全策略
- 在eclipse中配置maven项目
- jqGrid怎么设置初始化页面时不加载数据(不向服务器请求数据)
- Spring MVC 上传单个文件
- Java写程序猿专访String2
- Java中的hashCode 方法
- Spring+mybatis配置动态数据源
- 找不到要编译的文件——path环境变量配置
- Spring Data JPA 常用注解 @Query、@NamedQuery
- java MD5 加密(16位/32位)
- 【转】JAVA中的反射机制
- java内存区域