javaEE包括13门规范 在课程中主要学习 servlet技术 和 jsp技术java
其中 servlet规范包括三个技术点:servlet listener filter程序员
监听器就是监听某个对象的的状态变化的组件web
监听器的相关概念:面试
事件源:被监听的对象 ----- 三个域对象 request session servletContextspring
监听器:监听事件源对象 事件源对象的状态的变化都会触发监听器 ---- 6+2数据库
注册监听器:将监听器与事件源进行绑定apache
响应行为:监听器监听到事件源的状态变化时 所涉及的功能代码 ---- 程序员编写代码服务器
第一维度:按照被监听的对象划分:ServletRequest域 HttpSession域 ServletContext域session
第二维度:监听的内容分:监听域对象的建立与销毁的 监听域对象的属性变 化的jsp
1)Servlet域的生命周期
什么时候建立:服务器启动建立
什么时候销毁:服务器关闭销毁
2)监听器的编写步骤(重点):
a、编写一个监听器类去实现监听器接口
b、覆盖监听器的方法
c、须要在web.xml中进行配置---注册
3)监听的方法:
4)配置文件:
5)ServletContextListener监听器的主要做用
a、初始化的工做:初始化对象 初始化数据 ---- 加载数据库驱动 链接池的初始 化
b、加载一些初始化的配置文件 --- spring的配置文件
c、任务调度----定时器----Timer/TimerTask
任务调度:
/** * ServletContext域的建立与销毁的监听器 * ServletContextListener * 主要做用: * 1. 初始化的工做:初始化对象 初始化对象 ---加载数据库驱动 链接池的初始化 * 2. 加载一些初始化配置---spring的配置文件 * 3. 任务调度--定时器---Timer/TimerTask * @author vanguard * */ public class MyServletContextListener implements ServletContextListener { /** * 监听ServletContext域对象的建立 */ @Override public void contextInitialized(ServletContextEvent sce) { System.out.println("context建立了!!"); // //获取监听的ServletContext对象 // ServletContext servletContext = sce.getServletContext(); // //获取监听的ServletContext对象 // ServletContext source = (ServletContext) sce.getSource(); //任务调度--模拟定时计息 规定时间内开始 SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); Date parse = null;; try { parse = format.parse("2017-8-11 12:10:00"); } catch (ParseException e) { e.printStackTrace(); } Timer timer = new Timer(); timer.scheduleAtFixedRate(new TimerTask() { @Override public void run() { System.out.println("开始计息了。。。"); } }, parse, 1000*60*60*24); } /** * 监听ServletContext域对象的销毁 */ @Override public void contextDestroyed(ServletContextEvent sce) { System.out.println("context销毁了!!"); } }
1)HttpSession对象的生命周期
什么时候建立:第一次调用request.getSession时建立
什么时候销毁:服务器关闭销毁 session过时 手动销毁
2)HttpSessionListener的方法
1)ServletRequest的生命周期
建立:每一次请求都会建立request
销毁:请求结束
2)ServletRequestListener的方法
setAttribute(name,value)
--- 触发添加属性的监听器的方法
--- 触发修改属性的监听器的方法
getAttribute(name)
removeAttribute(name)
--- 触发删除属性的监听器的方法
/** * ServletContext域对象属性变化的监听器 * ServletContextAttributeListener * @author vanguard * */ public class MyServletContextAttributeListenerServlet implements ServletContextAttributeListener { @Override public void attributeAdded(ServletContextAttributeEvent sce) { System.out.println("添加了属性:" + sce.getName() + ":" + sce.getValue()); } @Override public void attributeReplaced(ServletContextAttributeEvent sce) { System.out.println("修改了属性:" + sce.getName() + ":" + sce.getValue()); } @Override public void attributeRemoved(ServletContextAttributeEvent sce) { System.out.println("删除了属性:" + sce.getName() + ":" + sce.getValue()); } }
绑定状态:就一个对象被放到session域中
解绑状态:就是这个对象从session域中移除了
钝化状态:是将session内存中的对象持久化(序列化)到磁盘
活化状态:就是将磁盘上的对象再次恢复到session内存中
面试题:当用户不少时,怎样对服务器进行优化?
@Override public void valueBound(HttpSessionBindingEvent event) { System.out.println("user被绑定到session域中了"); System.out.println(event.getName()); } @Override public void valueUnbound(HttpSessionBindingEvent event) { System.out.println("user从session域中解绑了"); System.out.println(event.getName()); }
能够经过配置文件 指定对象钝化时间 --- 对象多长时间不用被钝化
在META-INF下建立一个context.xml
<Context> <!-- maxIdleSwap:session中的对象多长时间不使用就钝化 --> <!-- directory:钝化后的对象的文件写到磁盘的哪一个目录下 配置钝化的对象文件在work/catalina/localhost/钝化文件 --> <Manager className="org.apache.catalina.session.PersistentManager" maxIdleSwap="1"> <Store className="org.apache.catalina.session.FileStore" directory="itcast205" /> </Manager> </Context>
@Override
public void sessionWillPassivate(HttpSessionEvent event) {
System.out.println("person被钝化了");
}
@Override
public void sessionDidActivate(HttpSessionEvent event) {
System.out.println("person被激活了");
}
被钝化到work/catalina/localhost/的文件