企业🤖AI Agent构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
[TOC] # 什么是监听器? 监听器就是监听某个对象的的状态变化的组件 监听器的相关概念: 事件源:被监听的对象 ----- 三个域对象 request, session, servletContext 监听器:监听事件源对象 事件源对象的状态的变化都会触发监听器 ---- 6+2 注册监听器:将监听器与事件源进行绑定 响应行为:监听器监听到事件源的状态变化时 所涉及的功能代码 ---- 程序员编写代码 ~~~ @WebListener ~~~ # 监听器有哪些? 第一维度:按照被监听的对象划分:ServletRequest域,HttpSession域,ServletContext域 第二维度:监听的内容分:监听域对象的创建与销毁的 监听域对象的属性变化的 ![](https://box.kancloud.cn/c18884dec08fb1dc6e93704bc5573b1d_937x124.png) # 监听三大域对象的创建与销毁的监听器 ## 监听ServletContext域的ServletContextListener 1. Servlet域的生命周期 何时创建:服务器启动创建 何时销毁:服务器关闭销毁 2. 监听器的编写步骤: * 编写一个监听器类去实现监听器接口 * 覆盖监听器的方法 * 需要在web.xml中进行配置---注册 3. 监听的方法 写个自定义的MyServletContextListener类实现ServletContextListener就可以 ~~~ package mytest; import javax.servlet.ServletContext; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; public class MyServletContextListener implements ServletContextListener { @Override public void contextDestroyed(ServletContextEvent arg0) { //获取被监听的对象 ServletContext servletContext = arg0.getServletContext(); //和上面一样,不过类型是Object,是通用的方法 Object source = arg0.getSource(); System.out.println("ServletContext销毁了"); } @Override public void contextInitialized(ServletContextEvent arg0) { System.out.println("ServletContext创建了"); } } ~~~ 4. 配置文件: ~~~ <!-- 注册监听器 --> <listener> <listener-class>mytest.MyServletContextListener</listener-class> </listener> ~~~ 5. ServletContextListener监听器的主要作用 * 初始化的工作:初始化对象 初始化数据 ---- 加载数据库驱动 连接池的初始 化 * 加载一些初始化的配置文件 --- spring的配置文件 * 任务调度----定时器----Timer/TimerTask ~~~ // 开启一个任务调度器 util包下的 Timer timer = new Timer(); // task任务 firstTimer:第一次执行时间 period:间隔执行时间 // timer.schedule(task, firstTime, period); timer.schedule(new TimerTask() { @Override public void run() { System.out.println("定时任务---"); } }, new Date(), 5000);// 5秒钟 ~~~ ## 监听Httpsession域的HttpSessionListener 1. HttpSession对象的生命周期 * 何时创建:第一次调用request.getSession时创建 * 何时销毁:服务器关闭销毁 session过期 手动销毁 2. HttpSessionListener的方法 ~~~ @Override public void sessionCreated(HttpSessionEvent se) { HttpSession session = se.getSession(); System.out.println("session创建: " + session.getId()); } @Override public void sessionDestroyed(HttpSessionEvent se) { HttpSession session = se.getSession(); System.out.println("session销毁: " + session.getId()); } ~~~ ## 监听ServletRequest域的ServletRequestListener 1. ServletRequest的生命周期 * 创建:每一次请求都会创建request * 销毁:请求结束 2. ServletRequestListener的方法 ~~~ @Override public void requestDestroyed(ServletRequestEvent sre) { sre.getServletRequest(); System.out.println("request销毁"); } @Override public void requestInitialized(ServletRequestEvent sre) { System.out.println("request创建"); } ~~~ # 监听三大域对象的属性变化的 1. 域对象的通用的方法: ~~~ setAttribute(name,value) --- 触发添加属性的监听器的方法 --- 触发修改属性的监听器的方法 getAttribute(name) removeAttribute(name) --- 触发删除属性的监听器的方法 ~~~ 2. ServletContextAttibuteListener监听器 ![](https://box.kancloud.cn/3b883c7fead785558e6bf07321be9da4_486x248.png) 3. HttpSessionAttributeListener监听器(同上) 4. ServletRequestAriibuteListenr监听器(同上) # session中的绑定的对象相关的监听器(对象感知监听器) 一个对象要钝化,要实现序列化接口, 那个对象放到session中需要某个功能就需要实现下面的监听器的接口 1. 即将要被绑定到session中的对象有几种状态 绑定状态:就一个对象被放到session域中 解绑状态:就是这个对象从session域中移除了 钝化状态:是将session内存中的对象持久化(序列化)到磁盘 活化状态:就是将磁盘上的对象再次恢复到session内存中 2. 绑定与解绑的监听器HttpSessionBindingListener ![](https://box.kancloud.cn/69484cb8a9a7aa84426e175c0bb50224_438x229.png) 3. 钝化与活化的监听器HttpSessionActivationListener 可以通过配置文件 指定对象钝化时间 --- 对象多长时间不用被钝化 在META-INF下创建一个context.xml ![](https://box.kancloud.cn/e75a00446379ef6abcc3f4c40de4f73f_148x101.png) ~~~ <Context> <!-- maxIdleSwap:session中的对象多长时间不使用就钝化 --> <!-- directory:钝化后的对象的文件写到磁盘的哪个目录下 配置钝化的对象文件在 work/catalina/localhost/钝化文件 --> <Manager className="org.apache.catalina.session.PersistentManager" maxIdleSwap="1"> <Store className="org.apache.catalina.session.FileStore" directory="study" /> </Manager> </Context> ~~~ ![](https://box.kancloud.cn/d04dac8de496cb0d5b896e6cb153a662_424x166.png) # 初始化参数 ~~~ <!-- 指定初始化参数 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>/abc</param-value> </context-param> ~~~ ~~~ @Override public void contextInitialized(ServletContextEvent sce) { //获取servletContext对象 ServletContext servletContext = sce.getServletContext(); //加载资源配置文件 String contextConfigLocation = servletContext.getInitParameter("contextConfigLocation"); //获取真实路径 String realPath = servletContext.getRealPath(contextConfigLocation); } ~~~