《Java Web技术及案例开发》 课件 第8章 Filter和Listener_第1页
《Java Web技术及案例开发》 课件 第8章 Filter和Listener_第2页
《Java Web技术及案例开发》 课件 第8章 Filter和Listener_第3页
《Java Web技术及案例开发》 课件 第8章 Filter和Listener_第4页
《Java Web技术及案例开发》 课件 第8章 Filter和Listener_第5页
已阅读5页,还剩44页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第8章Filter和Listener本章思维导图本章目标了解监听器原理及生命周期中的方法掌握Servlet上下文监听掌握Http会话监听了解请求监听理解过滤器原理及生命周期掌握实现一个过滤器的步骤过滤器(Filter)也称之为拦截器,是Servlet2.3规范新增的功能,在Servlet2.4规范中得到增强。Filter是Servlet技术中非常实用的技术,Web开发人员通过Filter技术,可以在用户访问某个Web资源(如:JSP、Servlet、HTML、图片、CSS等)之前,对访问的请求和响应进行拦截,从而实现一些特殊功能。例如,验证用户访问权限、记录用户操作、对请求进行重新编码、压缩响应信息等。过滤器简介在Web应用中,过滤器所处的位置:过滤器所处的位置一个过滤器的运行过程可以分解为如下几个步骤:Web容器判断接收的请求资源是否有与之匹配的过滤器,如果有,容器将请求交给相应过滤器进行处理;在过滤器预处理过程中,可以改变请求的内容,或者重新设置请求的报头信息,然后将请求发给目标资源;目标资源对请求进行处理后作出响应;容器将响应转发回过滤器;在过滤器后处理过程中,可以根据需求对响应的内容进行修改;Web容器将响应发送回客户端。过滤器的运行过程在一个Web应用中,也可以部署多个过滤器,这些过滤器组成了一个过滤器链。过滤器链中的每个过滤器负责特定的操作和任务,客户端的请求可以在这些过滤器之间进行传递,直到达到目标资源。例如,一个由两个Filter所组成的过滤器链的过滤过程:过滤器链过滤器的实现主要依靠以下核心接口:jakarta.servlet.Filter接口jakarta.servlet.FilterConfig接口jakarta.servlet.FilterChain接口过滤器核心接口与开发Servlet需要实现Servlet接口类似,开发Filter要实现jakarta.servlet.Filter接口,并提供一个公共的不带参数的构造方法。Filter接口的方法及说明Filter接口的方法及说明方法说明init(FilterConfigconfig)过滤器初始化方法。容器在过滤器实例化后调用此方法对过滤器进行初始化,同时向其传递FilterConfig对象,用于获得和Servlet相关的ServletContext对象doFilter(ServletRequestrequest,ServletResponseresponse,FilterChainchain)过滤器的功能实现方法。当用户请求经过时,容器调用此方法对请求和响应进行功能处理。该方法由容器传入三个参数对象,分别用于获取请求对象、响应对象和FilterChain对象,请求和响应对象类型分别为ServletRequest和ServletResponse,并不依赖于具体的协议,FilterChian对象的doFilter(request,response)方法负责将请求传递给下一个过滤器或目标资源destroy()该方法在过滤器生命周期结束前由Web容器调用,可用于使用资源的释放init(FilterConfigconfig)过滤器初始化方法。容器在过滤器实例化后调用此方法对过滤器进行初始化,同时向其传递FilterConfig对象,用于获得和Servlet相关的ServletContext对象过滤器的生命周期分为四个阶段:加载和实例化Web容器启动时,会根据@WebFilter属性filterName所定义的类名的大小写拼写顺序,或者web.xml中声明的Filter顺序依次实例化Filter。初始化Web容器调用init(FilterConfigconfig)方法来初始化过滤器。容器在调用该方法时,向过滤器传递FilterConfig对象。实例化和初始化的操作只会在容器启动时执行,并且只会执行一次。过滤器的生命周期doFilter()方法的执行当客户端请求目标资源的时候,容器会筛选出符合过滤器映射条件的Filter,并按照@WebFilter属性filterName所定义的类名的大小写拼写顺序,或者web.xml中声明的filter-mapping的顺序依次调用这些过滤器的doFilter()方法。在这个链式调用过程中,可以调用FilterChain对象的doFilter(ServletRequest,ServletResponse)方法将请求传给下一个过滤器(或目标资源),也可以直接向客户端返回响应信息,或者利用请求转发或重定向将请求转向到其它资源。需要注意的是,这个方法的请求和响应参数的类型是ServletRequest和ServletResponse,也就是说,过滤器的使用并不依赖于具体的协议。销毁Web容器调用destroy()方法指示过滤器的生命周期结束。在这个方法中,可以释放过滤器使用的资源过滤器的生命周期jakarta.servlet.FilterConfig接口由容器实现,容器将其实例作为参数传入过滤器(Filter)对象的初始化方法init()中,来获取过滤器的初始化参数和Servlet的相关信息。FilterConfig接口的主要方法及作用FilterConfig接口方法说明getFilterName()获取配置信息中指定的过滤器的名字getInitParameter(Stringname)获取配置信息中指定的名为name的过滤器初始化参数值getInitParameterNames()获取过滤器的所有初始化参数的名字的枚举集合getServletContext()获取Servlet上下文对象jakarta.servlet.FilterChain接口由容器实现,容器将其实例作为参数传入过滤器对象的doFilter()方法中。过滤器对象使用FilterChain对象调用过滤器链中的下一个过滤器,如果该过滤器是链中最后一个过滤器,那么将调用目标资源。FilterChain接口主要方法及作用FilterChain接口方法说明doFilter(ServletRequestrequest,ServletResponseresponse)该方法将使过滤器链中的下一个过滤器被调用,如果调用该方法的过滤器是链中最后一个过滤器,那么目标资源被调用在Servlet3.0以上版本中,既可以使用@WebFilter形式的Annotation对Filter进行声明配置,也可以在web.xml文件中进行配置。@WebFilter所支持的常用属性过滤器声明配置属性名类型是否必需说明filterNameString否用于指定该Filter的名称,默认为类名urlPatterns/valueString[]是用于指定该Filter所拦截的URL,两个属性相同但不能同时使用servletNamesString[]否用于指定该Filter对哪些Servlet执行过滤,可指定多个Servlet的名称,值是@WebServlet中的name属性的取值或web.xml中<servlet-name>的取值dispatcherTypesDispatcherType否用于指定该Filter对哪种模式的请求进行过滤,支持REQUEST、FORWARD、INCLUDE、ERROR、ASYNC这5个值的任意组合,默认值为REQUESTinitParamsWebInitParam[]否用于指定该Filter的一组配置参数asyncSupportboolean否指定该Filter是否支持异步操作模式displayNameString否用于指定该Filter的显示名称descriptionString否指定该Filter的描述信息过滤器通过属性urlPatterns/value指定的URL匹配模式来对匹配的请求地址进行拦截。属性urlPatterns/value指定的URL匹配模式有如下要求:URL匹配模式可以是路径匹配,也可以是扩展名匹配。例如,对请求地址“http://localhost:8080/chapter10/index.jsp”,路径匹配可以为“/index.jsp”或“/*”;扩展名匹配为“*.jsp”,但不能是路径匹配和扩展名匹配的混合,例如“/*.jsp”这种写法是错误的。过滤器的声明配置@WebFilter的属性dispatcherTypes的五个取值对应的转发模式的含义如下所示:REQUEST当用户直接对网页做出请求的动作时,才会通过此Filter。而例如请求转发发出的请求则不会通过此Filter。FORWARD指由RequestDispatcher对象的forward()方法发出的请求才会通过此Filter,除此之外,该过滤器不会被调用。INCLUDE指由RequestDispatcher对象的include()方法发出的请求才会通过此Filter,除此之为,该过滤器不会被调用。ERROR如若在某个页面使用page指令指定了error属性,那么当此页面出现异常跳转到异常处理页面时才会经过此Filter,除此之外,该过滤器不会被调用。ASYNC指异步处理的请求才会通过此过滤器,除此之外,该过滤器不会被调用。过滤器的声明配置在Web开发中,Filter是非常重要而且实用的技术,其应用非常广泛,如下为几种常见的使用情况:做统一的认证处理;对用户的请求进行检查和更精确的记录;监视或对用户所传递的参数做前置处理,例如:防止数据注入攻击;改变图像文件的格式;对请求和响应进行编码;对响应做压缩处理;对XML的输出使用XSLT来转换。

过滤器应用在前面章节的介绍中,对POST请求参数的乱码问题通常采用如下代码进行设置:使用这种方法有一个缺点:必须对每一个获得请求参数的程序都要加入上述程序代码。这种做法显然增加了重复的工作量,此时使用过滤器便可轻松予以解决。批量设置请求编码request.setCharacterEncoding("UTF-8");通过上述代码,当用户向服务器发送任意请求时,都会经过此过滤器对请求编码进行设置。需要注意的是,只有在最初使用请求对象的程序前进行编码设置,才会对后续使用程序起作用,因此,该过滤器在执行顺序上应该保证早于其它过滤器的执行。这种情况下,可以采用以下三种方式解决:方式一:完全基于Annotation的过滤器方式的配置,可以通过设置filterName按照过滤器的名称首字母顺序执行;方式二:完全使用web.xml的方式对过滤器链配置,相同映射条件下,按照<filter-mapping>定义的先后顺序执行;方式三:使用Annotation和web.xml相结合的方式配置,web.xml文件中声明的Filter的执行顺序早于使用Annotation声明的Filter。批量设置请求编码在Web应用中,有很多操作是需要用户具有相关的操作权限才可进行访问的,例如:用户个人中心、网站后台管理、同一系统不同角色的访问。这些应用的权限控制可以在具体的访问资源中单独设置,也可以使用过滤器统一设置,显然后者具有更高的效率和可维护性。该实例的实现思路如下:设置较为全面的请求拦截映射地址,但对于用户登陆页面及处理登录操作的Servlet不能进行访问限制,可用初始化参数灵活指定相关地址。通过判断会话对象中是否存在用户登陆成功时设置的域属性,来决定用户是否有访问的权限。控制用户访问权限Filter结合GZIP压缩技术是解决Web应用中网络传输大数据量问题的常用方法。GZIP是HTTP协议中使用的一种压缩算法,用于对服务器端响应内容进行压缩,减少网络传输数据量,提高服务器的响应速度。通过和Filter相配合,可以在无需改动应用现有代码的基础上引入该功能。压缩响应结果要实现对响应信息进行压缩的Filter程序,需要掌握以下几个技术要点和设计思想:浏览器通过发送类似“Accept-Encoding:gzip,deflate”请求头信息,告诉服务器该浏览器支持GZIP压缩;Filter通过Accept-Encoding请求头,来判断浏览器是否支持数据压缩和支持哪种格式的数据;如果浏览器不支持GZIP压缩格式,则不对目标资源输出的响应信息进行压缩,否则Filter需要创建一个包含压缩功能的自定义响应对象传递给目标资源,以便截获目标资源输出的响应信息,进而对其进行压缩处理。Filter创建的自定义响应对象首先应当保证与HttpServletResponse接口的规范一致,然后在此基础上重写输出响应消息内容的方法,进行压缩处理。ServletAPI提供了一个HttpServletResponseWrapper类来包装原始的response对象,自定义的响应对象可以继承此类,然后对其中输出响应消息内容的getOutputStream()、getWriter()和flushBuffer()方法进行重写。Web服务器程序使用JDK提供的java.util.zip.GZIPOutputStream类来将数据压缩成GZIP格式。GZIPOutputStream类通过其构造方法包装一个底层输出流对象,调用write()方法向底层输出流对象中写入压缩成GZIP格式的数据,最后关闭GZIPOutputStream对象。在原响应对象中添加响应头“Content-Encoding:gzip”,告诉浏览器响应信息使用GZIP压缩。浏览器接收到GZIP压缩数据后,根据响应头“Content-Encoding:gzip”来对响应内容进行解码,获取到原始响应数据进行显示。压缩响应结果在Web容器运行过程中,有很多关键点事件,比如Web应用被启动、被停止、用户会话开始、用户会话结束、用户请求到达、用户请求结束等,这些关键点为系统运行提供支持,但对用户却是透明的。ServletAPI提供了大量监听器接口来帮助开发者实现对Web应用内特定事件进行监听,从而当Web应用内这些特定事件发生时,回调监听器内的事件监听方法来实现一些特殊功能。监听器简介Web容器使用不同的监听器接口来实现对不同事件的监听,常用的Web事件监听器接口可分为如下三类:与Servlet上下文相关的监听器接口与会话相关的监听器接口与请求相关的监听器接口监听接口分类与Servlet上下文相关的监听器需要实现的监听器接口与Servlet上下文相关的监听器监听器接口名称说明ServletContextListener用于监听ServletContext(application)对象的创建和销毁ServletContextAttributeListener用于监听ServletContext(application)范围内属性的改变ServletContextListener接口用于监听Web应用程序的ServletContext对象的创建和销毁事件。每个Web应用对应一个ServletContext对象,在Web容器启动时创建,在容器关闭时销毁。当Web应用程序中声明了一个实现ServletContextListener接口的事件监听器后,Web容器在创建或销毁此对象时就会产生一个ServletContextEvent事件对象,然后再执行监听器中的相应事件处理方法,并将ServletContextEvent事件对象传递给这些方法。ServletContextListener在ServletContextListener接口中定义了如下两个事件处理方法:contextInitialized(ServletContextEventsce)当ServletContext对象被创建时,Web容器将调用此方法。该方法接收ServletContextEvent事件对象,通过此对象可获得当前被创建的ServletContext对象。contextDestroyed(ServletContextEventsce)当ServletContext对象被销毁时,Web容器调用此方法,同时向其传递ServletContextEvent事件对象。ServletContextListener上述事件处理方法中,ServletContextEvent为一个事件类,用于通知Web应用程序中上下文对象的改变。ServletContextEvent的方法及说明ServletContextListener方法说明getServletContext()返回改变前的ServletContext对象注解@WebListener用于对监听器进行声明。注解@WebListener的常用属性【示例】使用@WebListener声明配置监听器ServletContextListener@WebListener("持久存取页面访问计数")publicclassVisitCountListenerimplementsServletContextListener{属性名类型是否必需描述valueString否设置该监听器的描述信息ServletContextAttributeListener接口用于监听ServletContext(application)范围内属性的创建、删除和修改。当Web容器中声明了一个实现ServletContextAttributeListener接口的监听器后,Web容器在ServletContext应用域属性发生改变时就会产生一个ServletContextAttributeEvent事件对象,然后再调用监听器中的相应事件处理方法。ServletContextAttributeListenerServletContextAttributeListener接口中定义了如下三个事件处理方法:attributeAdded(ServletContextAttributeEventevent)当程序把一个属性存入application范围时,Web容器调用此方法,同时向其传递ServletContextAttributeEvent事件对象;attributeRemoved(ServletContextAttributeEventevent)当程序把一个属性从application范围删除时,Web容器调用此方法,同时向其传递ServletContextAttributeEvent事件对象;attributeReplaced(ServletContextAttributeEventevent)当程序替换application范围内的属性时,Web容器调用此方法,同时向其传递ServletContextAttributeEvent事件对象。ServletContextAttributeListener上述事件处理方法中,ServletContextAttributeEvent为一个事件类,用于通知Web应用程序中Servlet上下文属性的改变。ServletContextAttributeEvent的方法及说明:ServletContextAttributeListener方法说明getName()返回ServletContext改变的属性名getValue()返回已被增加、删除、替换的属性值,如果属性被增加,就是该属性的值;属性被删除,就是被删除属性的值;如果属性被替换,就是该属性的旧值与会话相关的监听器需要实现的监听器接口与会话相关的监听器监听器接口名称说明HttpSessionListener用于监听会话对象HttpSession的创建和销毁HttpSessionAttributeListener用于监听HttpSession(session)范围内属性的改变HttpSessionListener接口用于监听用户会话对象HttpSession的创建和销毁事件。每个浏览器与服务器的会话状态分别对应一个HttpSession对象,每个HttpSession对象在浏览器开始与服务器会话时创建,在浏览器与服务器结束会话时销毁。当在Web应用程序中声明了一个实现HttpSessionListener接口的事件监听器后,Web容器在创建或销毁每个HttpSession对象时都会产生一个HttpSessionEvent事件对象,然后调用监听器中的相应事件处理方法,同时将HttpSessionEvent事件对象传递给这些方法。HttpSessionListener在HttpSessionListener接口中定义了如下两个事件处理方法:sessionCreated(HttpSessionEventse)当HttpSession对象被创建时,Web容器将调用此方法。该方法接收HttpSessionEvent事件对象,通过此对象可获得当前被创建的HttpSession对象;sessionDestroyed(HttpSessionEventse)当HttpSession对象被销毁时,Web容器调用此方法,同时向其传递HttpSessionEvent事件对象。HttpSessionListener上述事件处理方法中,HttpSessionEvent为一个事件类,用于通知Web应用程序中会话对象的改变。HttpSessionEvent的方法及说明:HttpSessionListener方法说明getSession()返回改变前的HttpSession对象HttpSessionAttributeListener接口用于监听HttpSession(session)范围内属性的创建、删除和修改。当Web容器中声明了一个实现HttpSessionAttributeListener接口的监听器后,Web容器在HttpSession会话域属性发生改变时就会产生一个HttpSessionAttributeEvent事件对象,然后再调用监听器中的相应事件处理方法。HttpSessionAttributeListenerHttpSessionAttributeListener接口中定义了如下三个事件处理方法:attributeAdded(HttpSessionAttributeEventevent)当程序把一个属性存入session范围时,Web容器调用此方法,同时向其传递HttpSessionAttributeEvent事件对象;attributeRemoved(HttpSessionAttributeEventevent)当程序把一个属性从session范围删除时,Web容器调用此方法,同时向其传递HttpSessionAttributeEvent事件对象;attributeReplaced(HttpSessionAttributeEventevent)当程序替换session范围内的属性时,Web容器调用此方法,同时向其传递HttpSessionAttributeEvent事件对象。HttpSessionAttributeListener上述事件处理方法中,HttpSessionAttributeEvent为一个事件类,用于通知Web应用程序中会话对象属性的改变。HttpSessionAttributeEvent的方法及说明:HttpSessionAttributeListener方法说明getName()返回HttpSession改变的属性名getValue()返回已被增加、删除、替换的属性值,如果属性被增加,就是该属性的值;属性被删除,就是被删除属性的值;如果属性被替换,就是该属性的旧值与请求相关的监听器需要实现的监听器接口:与请求相关的监听器监听器接口名称说明ServletRequestListener用于监听用户请求的产生和结束ServletRequestAttributeListener用于监听ServletRequest(request)范围内属性的改变ServletRequestListener接口用于监听ServletRequest对象的创建和销毁事件。浏览器的每次访问请求分别对应一个ServletRequest对象,每个ServletRequest对象在每次访问请求开始时创建,在每次访问请求结束后销毁。当在Web应用程序中声明了一个实现ServletRequestListener接口的事件监听器后,Web容器在创建或销毁每个ServletRequest对象时都会产生一个ServletRequestEvent事件对象,然后将其传递给监听器中的相应事件处理方法。ServletRequestListenerServletRequestListener接口中定义了如下两个事件处理方法:requestInitialized(ServletRequestEventsre)当ServletRequest对象被创建时,Web容器将调用此方法。该方法接收ServletRequestEvent事件对象,通过此对象可获得当前被创建的ServletRequest对象;requestDestroyed(ServletRequestEventsre)当ServletRequest对象被销毁时,Web容器调用此方法,同时向其传递ServletRequestEvent事件对象。ServletRequestListener上述事件处理方法中,ServletRequestEvent为一个事件类,用于通知Web应用程序中ServletRequest对象的改变。ServletRequestEvent的方法及说明:ServletRequestListener方法说明getServletRequest()返回改变前的ServletRequest对象ServletRequestAttributeListener接口用于监听ServletRequest(request)范围内属性的创建、删除和修改。当Web容器中声明了一个实现ServletRequestAttributeListener接口的监听器后,Web容器在ServletRequest请求域属性发生改变时就会产生一个ServletRequestAttributeEvent对象,然后再调用监听器中的相应事件处理方法。ServletRequestAttributeListenerServletRequestAttributeListener接口中定义了如下三个事件处理方法:attributeAdded(ServletRequestAttributeEventevent)当程序把一个属性存入request范围时,Web容器调用此方法,并向其传递ServletRequestAttributeEvent事件对象;attributeRemoved(ServletRequestAttributeEventevent)当程序把一个属性从request范围删除时,Web容器调用此方法,并向其传递ServletRequestAttributeEvent事件对象;attributeReplaced(ServletRequestAttributeEventevent)当程序替换request范围内的属性时,Web容器调用此方法,并向其传递ServletRequestAttributeEvent事件对象。ServletReque

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论