学号:2020080604016 闫杰
什么是Filter
Filter过滤器
Fliter在web应用应用中的拦截过程如图
接下来,分步骤实现一个Filter程序,演示Filter程序如何对Servler程序的调用过程进行拦截的,如下:
注:都需要在web.xml文件进行配置
<filter>根元素用于注册一个Filter
<filter-name>子元素用于设置Filter名称
<filter-class>子元素用于设置Filter的完整名称
<filter-mapping>根元素用于设置一个过滤器所拦截的资源
<filter-name>子元素必须与<filter>中的<filter-name>子元素相同
<url-pattern>子元素用于匹配用户请求的URL
Filter映射
1.使用通配符“*”拦截用户的所有请求
Filter的<filter-mapping>元素用于配置过滤器拦截的资源信息,如果想让过滤器拦截所有的请求访问,那么就需要通配符“*”来实现
2.拦截不同方式的访问请求
在web文件中,一个<filter-mapping>元素用于配置一个Filter所负责拦截的资源。
<filter-mapping>元素中有一个特殊的子元素<fispatcher>,该元素用于指定过滤器所拦截的资源被Servlet容器调用的方式,<fispatcher>元素的值共有4个,如下:
(1)REQUEST
当用户直接访问页面时,web容器将会调用过滤器。如果是通过Request Dispatcher的include()或forward()方法访问的,那么该过滤器将不会被调用
(2)INCLUDE
如果目标资源是通过RequestDispatcher的include()方法访问的,那么该过滤器将被调用。除此之外,该过滤器不会被调用
(3)FORWARD
如果目标资源是通过RequestDispatcher的forwar()方法访问的,那么该过滤器将被调用。除此之外,该过滤器不会被调用
(4)ERROR
如果目标资源是通过声明式异常处理机制调用的,那么该过滤器将被调用,除此之外,过滤器不会被调用。
接下来将理解4个值的作用,接下来以FORWARD为咧,分步骤演示Filter对转发请求的拦截效果:
Filter链
这是Filter链的拦截过程
下面演示的就是Filter拦截MyServlet的同一个请求,如下:
FilterConfig接口
为了获取Filter程序在web.xml文件中的配置信息,S而letAPI提供了一个FilterConfig接口