Filter拦截器和Listen监听器
Filte过滤器概述
1 过滤器是一个驻留在服务器端的Web组件,可以截取用户端和资源之间的请求响应信息,并对信息进行过滤 过滤的工作流程。
过滤器作用描述 1 ,在HttpServletRequsst到达Servlet之前, 拦截客户的HttpServletRequsst 2 , 根据需要检查HttpServletRequsst,也可以修改HttpServletRequsst头和数据 3 , 在HttpServletRequsst到达客户端之前,拦截HttpServletResopnse 4 ,根据需要检查HttpServletResponse, 可以修改HttpServletResponse头 和数据。 过滤器的组成部分: 1 过滤源 A 所有符合规则的数据交互行为 2 过滤规则 3 过滤结果 过滤器的部署。 一.实现javax.servlet.Filter接口 1 void destory();销毁,在服务器关闭时调用,释放filter占用 的资源 2 。 void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws,IOException,ServletException; 过滤规则,自动执行的过滤代码,我们需要自定义的部分, 如果符合过滤规则, 则通过chain放行。如果不符合规则,则做出处理。 3 , void init(FilterConfig filterConfig) throws ServletException; 在服务器启动时自动调用,初始化Filte 过滤器在web.xml中的配置 一 : 过滤器的配置 1 web. xml 中 配置 <filter>和<filter-mapping> 标签(同Servlet 标签) A Filter 的元素,
关于URL -patttern-Filter的映射 一: 分类 1 路径映射: 以"/"开头 和以"/*"结尾的是 用来做路径映射的
2 。 扩展映射: 以" * "开头的是用来做扩展映射的
注意: 如果配置文件中 又出现/*的路径映射,又出现*.do 的带后缀名的扩展映射,会报服务器错误。例如:
Filter的生命周期; 1, Web服务器启动,产生filter实例 2 ,调用init方法,初始化filter 3, 当发送请求时, 调用dofilter 4, Web容器关闭时,调用destroy方法释放资源 说明: Filter 使用户可以改变一个request和修改一个response。Filter不是一个servlet , 它不能产生一个response,也可以在response离开servlet时处理response,换句话说,Filter更像是一个servlet chaning 配置多个过滤器: 一 : 在一个web 应用中,可以部署多个过滤器,组成一个过滤器链。过滤器链中的每个过滤器负责特定的操作和任务,客户端的请求在这些过滤器之间传递,直到目标资源 多个Filter的处理流程
listener 概述
listener 用于监听java web程序中的事件,例如创建,修改,删除session,request,context 等,并触发响应的事件。 listener 对应观察者模式,事件发生的时候会自动触发该时间对应的listener,listener 主要用于对session,request,context进行监控,servlet2.5规范中共有8种listener。 实现: 不同功能的listener 需要实现不同的listener接口,一个listener也可以实现多个接口,这样就可以多种功能的监听器一个工作。 8种监听器可以分为三类: 1 , 监听 Session、request、context 的创建与销毁,分别为 HttpSessionLister、ServletContextListener、ServletRequestListener 2 , 监听对象属性变化,分别为: HttpSessionAttributeLister、 ServletContextAttributeListener、ServletRequestAttributeListener 3 , 监听Session 内的对象,分别为HttpSessionBindingListener 和 HttpSessionActivationListener。与上面六类不同,这两类 Listener 监听的是Session 内的对象,而非 Session 本身,不需要在 web.xml中配置。 单态登录监听器。
更多精彩

