监听器的概念
web应用当中监听器是什么:
web应用服务器—>监听器<—>Session<—用户访问
定义:监听器是Servlet中的一种特殊类,用于监听ServletContext、HttpSession和ServletRequset等域对象的创建与销毁事件,以及监听这些域对象的属性发生修改的事件。
监听器可以在事件发生前、发生后做一些必要的处理。
监听器的用途
统计用户在线人数、在线用户
系统启动时加载初始化信息,如缓存、公共变量、数据库连接、定时器等等
统计网站访问量
跟Spring结合
监听器的启动顺序
Servlet2.5下是以web.xml中的配置顺序加载的;
Servlet3.0下没有办法制定顺序。
加载 顺序:
监听器>过滤器>Servlet
监听器的分类
按对象划分:
1.监听应用程序环境对象ServletContext
2.监听用户会话对象HttpSession
3.监听请求消息对象ServletRequset
按监听事件划分:
1.监听域对象自身的创建和销毁
每个Listener 两个事件处理方法:初始化、销毁
ServletContext ServletContextListener主要用途:定时器、全局属性对象
HttpSession HttpSessionListener 主要用途:统计在线人数、记录访问日志
ServletRequset主要用途:读取参数、记录访问历史
2.监听域对象的属性的增加和删除
每个AttributeListener三个事件处理方法:AttributeAdded(增加)、AttributeRemoved(删除)、AttributeReplaced(替换)
ServletContext ServletContextAttributeListener主要用途:定时器、全局属性对象
HttpSession主要用途:统计在线人数、记录访问日志
ServletRequset主要用途:读取参数、记录访问历史
3.监听绑定到HttpSession域中的某个对象的状态
绑定—>解除绑定 绑定:session.setAttribute 解除绑定:session.removeAttribute
钝化—>活化 钝化:session对象持久化存储活化:将持久化的session从存储设备恢复到内存
session钝化机制:将服务器中不经常使用的session对象暂时序列化到系统文件系统或数据库系统中,当被使用时反序列化到内存中,整个过程由服务器自动完成。
HttpSessionBindingListener 绑定:valueBound方法解除绑定:valueUnbound方法
HttpSessionActivationListener 钝化:sessionWillPassivate方法活化:sessionDidActivate方法
这两个监听器不需要在web.xml注册
在Servlet3.0下的使用
@WebListener
监听器的实例
步骤:
1.创建一个实现监听器类接口的类
2.配置web.xml进行注册
一个简单的监听器,打印requset参数中参数名为name的参数值
public class MyServletRequestListener implements ServletRequestListener {
@Override
public void requestDestroyed( ServletRequestEvent arg0 ) {
}
@Override
public void requestInitialized( ServletRequestEvent arg0 ) {
System.out.println( arg0.getServletRequest().getParameter( "name" ) );
}
}
web.xml中配置监听器
<listener>
<listener-class>com.test.example.MyServletRequestListener</listener-class>
</listener>