Servlet监听器:Servlet规范中定义的一种特殊类,它用来监听四大域的三个:
监听ServletContext,HttpSession,ServletRequest的创建与销毁。
以及这三个对象的属性被修改的事件
常见使用举例:创建数据库连接池,读取web应用初始化参数,创建Spring的IOC容器。
HttpSession和HttpRequest参照前面文章介绍。
-void contextDestroyed(ServletContextEvent sce)
web应用加载被创建,卸载被销毁。
-void sessionDestroyed(HttpSessionEvent se)
可以用来模糊统计在线人数,创建session+1,销毁后-1
第一次访问一个JSP或者Servlet时,且JSP或Servlet中允许,并且尚没创建session时,
服务器会创建Session.
调用session.invalidate()方法时,被销毁。
客户端浏览器关闭,不会销毁session
由于session有持久化处理,服务器端重启不一定会销毁Session
如果想让浏览器保留上一次的session,比如保留持续登录的状态,可以将session写入cookie,下次自动读出。
Cookie cookie = new Cookie("JSESSIONID", pageContext.getSession().getId());
cookie.setMaxAge(6000);
response.addCookie(cookie);
注意:由于session的Attribute是保存在服务器端的。
同一个sessionID就可以访问上次的Attribute内容。
-void requestInitialized(ServletRequestEvent sre)
发送请求时被创建,一个请求返回时,立即被销毁。
foward转发时,共用一个request。
sendRedirect是不同的request。
<listener>
<listener-class>xxxListener</listener-class>
</listener>
HttpSessionAttributeListener
ServletRequestAttributeListener
他们可以监听的内容是一样的:
void attributeAdded( event)
void attributeRemoved( event)
void attributeReplaced( event)
需要对应的javaBean实现下面接口即可,当JavaBean被session绑定,或者解除时
会触发相应的监听器。
※注意如果要使用磁盘读写操作,则需要实现Serializable接口
实现了HttpSessionBindingListener的JavaBean对象,如果同时实现该接口
则可以感知自己被活化(从硬盘中读出,比如服务器启动时)和钝化(写到硬盘,比如服务器关闭)的事件。
活化后触发:void sessionDidActivate(HttpSessionEvent se)
即将钝化触发:void sessionWillPassivate(HttpSessionEvent se)
<完>
监听ServletContext,HttpSession,ServletRequest的创建与销毁。
以及这三个对象的属性被修改的事件
监听类型主要分为三种:
1.监听域对象自身的创建和销毁。
ServletContext web应用被加载时创建,web应用被卸载时销毁,※是最常用的Listener。常见使用举例:创建数据库连接池,读取web应用初始化参数,创建Spring的IOC容器。
HttpSession和HttpRequest参照前面文章介绍。
ServletContextListener接口
-void contextInitialized(ServletContextEvent sce)-void contextDestroyed(ServletContextEvent sce)
web应用加载被创建,卸载被销毁。
HttpSessionListener接口
-void sessionCreated(HttpSessionEvent se)-void sessionDestroyed(HttpSessionEvent se)
可以用来模糊统计在线人数,创建session+1,销毁后-1
第一次访问一个JSP或者Servlet时,且JSP或Servlet中允许,并且尚没创建session时,
服务器会创建Session.
调用session.invalidate()方法时,被销毁。
客户端浏览器关闭,不会销毁session
由于session有持久化处理,服务器端重启不一定会销毁Session
如果想让浏览器保留上一次的session,比如保留持续登录的状态,可以将session写入cookie,下次自动读出。
Cookie cookie = new Cookie("JSESSIONID", pageContext.getSession().getId());
cookie.setMaxAge(6000);
response.addCookie(cookie);
注意:由于session的Attribute是保存在服务器端的。
同一个sessionID就可以访问上次的Attribute内容。
ServletRequestListener接口
-void requestDestroyed(ServletRequestEvent sre)-void requestInitialized(ServletRequestEvent sre)
发送请求时被创建,一个请求返回时,立即被销毁。
foward转发时,共用一个request。
sendRedirect是不同的request。
若让Listener有效,在wem.xml中配置即可。
实现Listener很简单,只需要实现上述对应的接口,注意由于是接口,当然可以用一个类,将三个接口全部实现。<listener>
<listener-class>xxxListener</listener-class>
</listener>
2.监听域对象中的属性的增加和删除的事件监听器
ServletContextAttributeListenerHttpSessionAttributeListener
ServletRequestAttributeListener
他们可以监听的内容是一样的:
void attributeAdded( event)
void attributeRemoved( event)
void attributeReplaced( event)
3.监听绑定到HttpSession域中的某个对象的状态的事件监听器。
HttpSessionBindingListener
该Listenser不需要再web.xml中绑定即可自动跟踪监听。需要对应的javaBean实现下面接口即可,当JavaBean被session绑定,或者解除时
会触发相应的监听器。
HttpSessionActivationListener
该Listener涉及到JavaBean的持久化处理(内存写到硬盘,从硬盘读到内存)※注意如果要使用磁盘读写操作,则需要实现Serializable接口
实现了HttpSessionBindingListener的JavaBean对象,如果同时实现该接口
则可以感知自己被活化(从硬盘中读出,比如服务器启动时)和钝化(写到硬盘,比如服务器关闭)的事件。
活化后触发:void sessionDidActivate(HttpSessionEvent se)
即将钝化触发:void sessionWillPassivate(HttpSessionEvent se)
<完>