前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【干货】你还分不清Java监听器与过滤器吗?

【干货】你还分不清Java监听器与过滤器吗?

作者头像
老九君
发布2019-05-31 10:57:20
5990
发布2019-05-31 10:57:20
举报
文章被收录于专栏:老九学堂老九学堂

什么是监听器?

它是一种Servlet中特殊的类,能监听某个对象的状态变化的组件,主要是监听域对象的变化。

比如说域对象的创建和销毁,监听器都可以知道。

在了解监听器前,我们先了解监听器相关的一些概念:

1.事件源:发出事件被监听的对象,主要监听的对象有三个:request域、session域、servletContext域

2.监听器:相当于代理对象,监听事件源的对象,有8个监听器。

3.注册监听器:监听器与事件源相绑定,让监听器成为事件的代理

4.响应行为:监听到事件源变化时,去做具体的事情

我们可以将监听器进行一个划分:

1.三个监听域对象的创建与销毁,即域对象一创建或一销毁,它都可以通知到我们,我们可以去做一些事情。监听器分别是ServletContextListener、HttpSessionListenerServletRequestListener。

2.三个监听域对象当中属性的变化,监听器分别是

ServletContextAttributeListener、HttpSessionAttributeListener、ServletRequestAttributeListener。

ServletContext域监听器

监听ServletContext域的创建与销毁的监听器ServletContextListener,我们知道ServletContext域的生命周期是在服务器启动时就创建,服务器关闭时就销毁的。

那么我们监听服务器启动和服务器关闭的作用是做什么呢?

比如说服务器一启动,我们就可以去做一些初始化的工作。

初始化对象、初始化数据、加载数据库驱动、连接器的初始化之类的以及加载一些初始化的配置文件,做一些任务调度等。

监听器的编写步骤:

1.编写一个监听器类去实现监听器接口

2.覆盖监听器中的方法

3.在web.xml中配置一下,让它成为代理,建立关联

Session域监听器

监听HttpSession域的创建与销毁的监听器HttpSessionListener,HttpSession的生命周期是在第一次调用request.getSession时创建,服务器关闭、session过期或手动调用方法销毁时就销毁。

它的编写步骤与ServletContextListener是一样的。

在实际开发中的应用场景:记录访问人数。

访问时,创建session,它就会通知我们,我们就可以去把人数加1,当用户退出的时候,session关闭,总人数就减1。

Request域监听器

监听Reuquest域的创建与销毁的监听器ServletRequestListener,它的创建和销毁很频繁,服务器启动就会有很多request创建。

在实际开发中,应用场景很少它的用法与上面的两个域监听器是一样的。

域对象属性监听器

添加、删除、更新数据,都可以通过对应域属性监听器来监听。

这里我们以ServletContext域作示例:

什么是过滤器?

过滤器是个很重要的技术,一些Web框架比如Struts和Spring框架内部的核心就是使用过滤器来实现的。

1.filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行。

2.可以对目标资源访问前后进行逻辑处理,即在客户端和服务端之间设置一道关卡,只有通过这道关卡才能访问到对应的资源。

在这个拦截的关卡这里,我们就可以做一些逻辑的处理。

过滤器编写步骤:

1.编写一个过滤器的类实现Filter接口

2.实现接口中尚未实现的方法(主要是DoFilter方法)

3.在web.xml中进行配置(主要是对哪些资源进行过滤)

代码示例:

访问一个资源的时候,会被过滤器拦截,要在过滤器当中进行放行之后,才能够通过chain.doFilter(req,res)访问到对应的servlet。

过滤器的访问流程

在发送一个请求时,web容器会先到filter当中,创建三个参数:res、req、chain。

在过滤器中,放行之后,才能访问到对应的资源。中间的过滤可能有多个,在一个过滤器中,可以调用另外一个过滤器。

也有可能过滤器没有拦截所有资源,有些资源可以直接被访问。

filter的生命周期

init方法,当filter对象创建时调用。当服务器启动时创建。

因为有可能一个filter对应多个servlet,启动时要先提前把filter准备好,访问资源时就可以进行过滤了。

我们可以通过init方法中的参数filterconfig(当前filter对象的配置信息,和servletConfig差不多),获取名称、参数、servletContext对象等。

destroy方法,当filter对象销毁时调用,关闭服务器时销毁对象,和servletContext的生命周期是一样的。

dofitter方法,当匹配到mapping时调用filter。

参数:res、req、filterChain,filterChain是过滤器链对象,内部维护者各个filter的索引,并且知道所有filter的顺序,是根据mapping的顺序来执行的。

过滤器的配置

mapping的几种写法

完全匹配:/MyServlet

目录匹配:/lcy/MyServlet,表示只能是lcy这个目录的才能访问

扩展名匹配:/*.xxx,开发中不常用

servlet_name(了解就行)

1.可以把路径直接指定某一个servlet

2.可以有多个servlet_name

3.开发中基本使用的都是mapping

dispatcher(了解就行)

配置请求的形式,不是请求方式,是页面跳转的形式

形式分类:

REQUEST:默认值,代表直接访问某个资源时执行filter

ERROR:发生错误时,进行跳转是执行filter

INCLUDE:包含资源时执行filter

FORWARD:转发时才执行filter

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 老九学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档