监听器 listener
其中 servlet规范包括三个技术点:servlet listener filter
什么是监听器?
监听器就是监听某个对象的的状态变化的组件
监听器的相关概念:
事件源:被监听的对象 —– 三个域对象 request、session、servletContext
监听器:监听事件源对象 事件源对象的状态的变化都会触发监听器 —6+2
注册监听器:将监听器与事件源进行绑定
响应行为:监听器监听到事件源的状态变化时 所涉及的功能代码 —程序员编写代码
监听器有哪些?
第一维度:按照被监听的对象划分:ServletRequest域 HttpSession域 ServletContext域
第二维度:监听的内容分:监听域对象的创建与销毁的 监听域对象的属性变化的
监听三大域对象的创建与销毁
监听ServletContext域的创建与销毁的监听器:ServletContextListener
Servlet域的生命周期
何时创建:服务器启动创建
何时销毁:服务器关闭销毁
监听器的编写步骤(重点)
a、编写一个监听器类去实现监听器接口
b、覆盖监听器的方法
c、需要在web.xml中进行配置—注册
监听的方法:
1 | public class MyServletContextListener implements ServletContextListener{ |
1 | <!-- 在web.xml中注册监听器 --> |
ServletContextListener监听器的主要作用
- 初始化的工作:初始化对象 初始化数据 —- 加载数据库驱动 连接池的初始化
- 加载一些初始化的配置文件 — spring的配置文件
- 任务调度—-定时器—-Timer/TimerTask
监听Httpsession域的创建于销毁的监听器:HttpSessionListener
HttpSession对象的生命周期
何时创建:第一次调用request.getSession时创建
何时销毁:服务器关闭销毁、session过期、手动销毁
HttpSessionListener的方法
1 | public class MyHTTPSessionListener implements HttpSessionListener { |
监听ServletRequest域创建与销毁的监听器:ServletRequestListener
ServletRequest的生命周期
何时创建:每一次请求都会创建request
何时销毁:请求结束
ServletRequestListener的方法
1 | public class MyServletRequqestListener implements ServletRequestListener { |
监听三大域对象的属性变化
域对象的通用的方法
setAttribute(name,value) 方法创建或改变某个新属性
getAttribute(name) 方法通过名称获取属性的值
removeAttribute(name) 方法通过名称删除属性的值
ServletContextAttibuteListener的方法
1 | public class MyServletContextAttributeListener implements ServletContextAttributeListener{ |
HttpSessionAttributeListener、ServletRequestAriibuteListenr监听器方法同上,故此不再赘述
与session中的绑定的对象相关监听器
与session中的绑定的对象相关监听器即是对象感知监听器
绑定状态:就一个对象被放到session域中
解绑状态:就是这个对象从session域中移除了
钝化状态:是将session内存中的对象持久化(序列化)到磁盘
活化状态:就是将磁盘上的对象再次恢复到session内存中
当用户很多时,怎样对服务器进行优化?这就涉及到对象的钝化与活化,只要把内存中的对象存储到磁盘中就可以从很大程度上减轻内存的消耗,从而达到服务器优化的目的!
绑定与解绑的监听器:HttpSessionBindingListener
1 | public class Person implements HttpSessionBindingListener{ |
1 | protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
钝化与活化的监听器:HttpSessionActivationListener
1 | public class Students implements HttpSessionActivationListener,Serializable{ |
想要实现对象的钝化和活化的时候需要实现Serializable接口,这个属于对象序列化的接口就不赘述了
1 | public class AServlet extends HttpServlet { |
首先我们访问这个AServlet,然后关掉服务器,注意:不要点击控制台那个停止,如图所示:
此时session域的对象会转储到apache-tomcat-7.0.92\work\Catalina\localhost\你的工程路径
这个文件夹中
重新启动服务器后访问BServlet的时候,对象便会活化,重新加载到内存,监听器监听到后便会执行相关的函数:
1 | public class BServlet extends HttpServlet { |
可以通过配置文件指定对象钝化时间 —> 对象多长时间不用被钝化
在META-INF下创建一个context.xml:
1 | <Context> |
过滤器 filter
filter的简介
过滤器可以拦截所有访问web资源的请求或响应操作。执行过滤任务的对象,这些任务是针对对某一资源(servlet 或静态内容)的请求或来自某一资源的响应执行的,抑或同时针对这两者执行 ,是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标资源访问前后进行逻辑处理,下面是Filter的基本使用流程:
- 编写一个过滤器的类实现Filter接口
- 实现接口中尚未实现的方法(着重实现doFilter方法)
- 在web.xml中进行配置(主要是配置要对哪些资源进行过滤)
filter生命周期及其API
Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法
init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行
doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法
destory():代表是filter销毁方法 当filter对象销毁时执行该方法
Filter对象的生命周期:
Filter何时创建:服务器启动时就创建该filter对象
Filter何时销毁:服务器关闭时filter销毁
1 | public class QuickFilter1 implements Filter{ |
web.xml文件的配置:
注意:Filter的过滤顺序是按照filter-mapping的顺序过滤的
1 | <filter> |
Filter的API详解
init(FilterConfig)方法
其中参数config代表 该Filter对象的配置信息的对象,内部封装是该filter的配置信息。
假设web.xml配置了如下的Filter:
1 | <filter> |
那么在filterConfig中就油API可以获取这些配置:
1 | //Filter的过滤顺序是按照filter-mapping的顺序过滤的 |
destory()方法
filter对象销毁时执行
doFilter方法
1 | doFilter(ServletRequest,ServletResponse,FilterChain) |
其中的参数:
ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request个该response就是在访问目标资源的service方法时的request和response。
FilterChain:过滤器链对象,通过该对象的doFilter方法可以放行该请求
Filer的配置
url-pattern配置时:
- 完全匹配
/sertvle1
- 目录匹配
/aaa/bbb/*
使用的最多的方法
/user/*
:访问前台的资源进入此过滤器
/admin/*
:访问后台的资源时执行此过滤器
- 扩展名匹配
*.txt
、*.jsp
注意:url-pattern可以使用servlet-name替代,也可以混用
dispatcher:该属性指定了对某种访问方式的过滤:
REQUEST:默认值,代表直接访问某个资源时执行filter
FORWARD:转发时才执行filter
INCLUDE: 包含资源时执行filter
ERROR:发生错误时 进行跳转是执行filter
Filter的作用
公共代码的提取
可以对request和response中的方法进行增强(装饰者模式/动态代理)
这个特点用一个示例来解决get请求或者post请求乱码的问题
对于POST请求:
1 | //第一种 |
1 | <!-- 设置编码 --> |
对于GET请求:
1 | public class EncodingFilter implements Filter{ |
- 进行权限控制
下面是一个使用了过滤器自动登录的示例:
过滤器的核心代码:(其他业务逻辑如上图所示)
1 | public class AutoLoginFilter implements Filter{ |
- 本文作者: Tim
- 本文链接: https://zouchanglin.cn/2018/04/30/2616280680.html
- 版权声明: 本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 许可协议。转载请注明出处!