一、监听器Listener
javaEE的13们规范中 包括servlet技术和jsp技术
servlet规范中包括三门技术:(servlet的三大组件)
servelt技术 Listener技术 Filter技术
1.什么是监听器
javaEE中的监听器 监听某些对象的状态变化的
事件源:被监听的对象,三个域对象(request域 session域 servletContext域)
监听器:监听三个域对象的状态变化的接口
响应行为:当监听器被触发后,需要执行的代码
监听器的绑定:动作 将监听器注册到事件源身上
2.监听器的种类(6+2)
监听器分为两种:
第一种:监听三个域对象的6个
第二种:监听要被放置到session域中的对象的状态的(感知监听器)
3.监听三个域对象的监听器 6个
第一维度:根据域对象不同分为三种
第二维度:根据监听域对象的不同状态分为两种
ServletContext域 |
HttpSession域 |
ServletRequest域 |
|
监听域对象的创建与销毁 |
ServletContextListeer |
HttpSessionListener |
ServletRequestListener |
监听域对象中的属性变化的 |
ServletContextAttributeListeer |
HttpSessionAttributeListener |
ServletRequestAttributeListener |
4.怎样编写一个监听器
1)创建一个监听器类去实现监听器接口
2)覆盖接口中的尚未实现的监听方法
3)需要在web.xml中配置监听器
5.ServletContextListener
监听ServletContext对象的创建与销毁的
ServletContext对象何时创建于销毁?
创建:服务器启动就要创建该对象
销毁:服务器关闭销毁
1 @Override 2 public void contextInitialized(ServletContextEvent sce) { 3 //被监听的对象 4 ServletContext servletContext = sce.getServletContext(); 5 ServletContext source = (ServletContext) sce.getSource(); 6 System.out.println("servletContext创建了"); 7 } 8 9 @Override 10 public void contextDestroyed(ServletContextEvent sce) { 11 System.out.println("servletContext销毁了"); 12 }
ServletContontextListenter的作用?
1)进行一些初始化的操作,加载初始化文件,创建初始化的数据
2)加载一些框架配置文件---使框架介入到web中
3)执行任务调度----定时器
6.HttpSessionListener
监听HttpSession对象的创建与销毁的
HttpSession域的创建于销毁
创建:第一次指定request.getSession()
销毁:服务器关闭、session超时、手动销毁
1 @Override 2 public void sessionCreated(HttpSessionEvent se) { 3 System.out.println("session创建了,jsessionid:"+se.getSession().getId()); 4 } 5 6 @Override 7 public void sessionDestroyed(HttpSessionEvent se) { 8 System.out.println("session销毁了,jsessionid:"+se.getSession().getId()); 9 }
HttpSession的作用?
记录当前网站的在线的人数
扫描session过期时间
7.ServletRequestListener
监听request对象创建与销毁的
request对象何时创建与销毁?
创建:每次访问service方法都会创建request
销毁:请求响应后request对象销毁
1 @Override 2 public void requestInitialized(ServletRequestEvent sre) { 3 System.out.println("request对象创建了"); 4 } 5 6 @Override 7 public void requestDestroyed(ServletRequestEvent sre) { 8 System.out.println("request对象销毁了"); 9 }
8.监听域对象中属性变化的三个监听器
ServletContextAttributeListener
HttpSessionAttributeListener
ServletRequestAttributeListener
域对象通用的方法:
setAttribute:新增属性/修改属性
getAttribute
removeAttribute:移除属性
1 @Override 2 //域中新增属性 3 public void attributeAdded(ServletRequestAttributeEvent srae) { 4 System.out.println("request域中新增:"+srae.getName()+"--"+srae.getValue()); 5 } 6 7 @Override 8 //删除域中的属性 9 public void attributeRemoved(ServletRequestAttributeEvent srae) { 10 System.out.println("request域中删除:"+srae.getName()+"--"+srae.getValue()); 11 12 } 13 14 @Override 15 //修改域中属性 16 public void attributeReplaced(ServletRequestAttributeEvent srae) { 17 System.out.println("request域中修改:"+srae.getName()+"--"+srae.getValue()); 18 }
9.感知监听器
注意:将要被放置到session中的对象自己可以感知,监听器绑到被放到session域中的对象身上。
注意:感知监听器不需要配置
session中对象的状态:
1)绑定状态 session.setAttribute(“user”,user);
2)解绑状态 session.removeAttribute(user)
3)钝化状态 将session中对象的持久化磁盘的过程
4)活化状态 将磁盘上存储对象信息恢复到session中
注意:钝化与活化的过程是web容器控制的
问试题:当服务器中用户比较多时候,怎样去优化?
其中一方面的回答:从session过多的角度去回答
绑定与解绑HttpSessionBindingLinstener
钝化与活化HttpSessionActivationListener
二、过滤器Filter
1.filter的简介
filter是对客户端访问资源的过滤,符合条件放行,不符合条件
2.快速入门
步骤:
1)编写一个过滤器的类实现Filter接口
2)实现接口中尚未实现的方法(着重实现doFilter方法)
3)在web.xml中进行配置(主要是配置要对哪些资源进行过滤)
3.Filter的API详解
(1)filter生命周期及其与生命周期相关的方法
Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法
init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行
doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法
destory():代表是filter销毁方法 当filter对象销毁时执行该方法
Filter对象的生命周期:
Filter何时创建:服务器启动时就创建该filter对象
Filter何时销毁:服务器关闭时filter销毁
(2)Filter的API详解
1)init(FilterConfig)
其中参数config代表 该Filter对象的配置信息的对象,内部封装是该filter的配置信息。
2)destory()方法
filter对象销毁时执行
3)doFilter方法
doFilter(ServletRequest,ServletResponse,FilterChain)
其中的参数:
ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request和response就是在访问目标资源的service方法时的request和response。
FilterChain:过滤器链对象,该对象封装所有的filter的引用
1 @Override 2 public void init(FilterConfig filterConfig) throws ServletException { 3 String filterName = filterConfig.getFilterName(); 4 System.out.println(filterName); 5 ServletContext servletContext = filterConfig.getServletContext(); 6 String initParameter = filterConfig.getInitParameter("aaa"); 7 System.out.println(initParameter); 8 9 System.out.println("filter1创建...."); 10 } 11 12 @Override 13 public void doFilter(ServletRequest request, ServletResponse response, 14 FilterChain chain) throws IOException, ServletException { 15 System.out.println("filter1 running。。。。。"); 16 //代表放行----不进行拦截操作 去访问目标资源 17 chain.doFilter(request, response); 18 } 19 20 @Override 21 public void destroy() { 22 System.out.println("filter1销毁...."); 23 }
4.Filter的配置
1 <!-- 解决中文提交乱码的filter --> 2 <filter> 3 <filter-name>EncodingFilter</filter-name> 4 <filter-class>cn.itcast.encoding.EncodingFilter</filter-class> 5 </filter> 6 <filter-mapping> 7 <filter-name>EncodingFilter</filter-name> 8 <url-pattern>/*</url-pattern> 9 </filter-mapping>
url-pattern配置时
1)完全匹配 /sertvle1
2)目录匹配 /aaa/bbb/* ----最多的
/user/*:访问前台的资源进入此过滤器
/admin/*:访问后台的资源时执行此过滤器
3)扩展名匹配 *.abc *.jsp
注意:url-pattern可以使用servlet-name替代,也可以混用
dispatcher:访问的方式(了解)
REQUEST:默认值,代表直接访问某个资源时执行filter
FORWARD:转发时才执行filter
INCLUDE: 包含资源时执行filter
ERROR:发生错误时 进行跳转是执行filter
总结Filter的作用?
1)公共代码的提取
2)可以对request和response中的方法进行增强(装饰者模式)
3)进行权限控制