过滤器的运行方式
首先,在一个应用程序中,可以设置多个过滤器,那么一个请求会被多个过滤器所过滤。其次,可以设置只有以某种方式访问网页或Servlet的时候,才能触发过滤器。在Servlet 2.3规范中,一共设置了四种触发过滤器的访问方式,即:REQUEST,FORWARD,INCLUDE和ERROR。见下表,
REQUEST | 当用户直接对网页做出请求的动作时,才会通过此Filter。因此,当用户通过RequestDispatcher方法的转向请求(forward)时,不会通过此Filter。 |
FORWARD | 当用户的请求是通过RequestDispatcher的forward方法时,才会通过此Filter。其他请求方式则不会通过此Filter。 |
INCLUDE | 当用户的请求是通过RequestDispatcher的include方法时,才会通过此Filter,其他请求方式不会通过此Filter。 |
ERROR | 当用户的请求是通过错误机制处理的时候,才会通过此Filter,同样,其他请求方式则不会通过此Filter。 |
其中,错误机制是指在web.xml中设置发生网页找不到错误,或者在访问页面抛出异常,导致重定向到其他页面时产生的错误。web.xml的错误机制设置如下所示:
<error-page>
<error-code>404</error-code>
<location>/notFileFound.jsp</location>
</error-page>
<error-page>
<exception-type>java.lang.NullPointerException</exception-type>
<location>/null.jsp</location>
</error-page>
这样设置web.xml后,一旦发生404错误,就会转向/error404.jsp页面,如果同时设置了访问方式为ERROR的过滤器,那么在转向该页面之前,同时会触发过滤器。
下面是为Filter配置触发方式的例子:
<filter>
<filter-name>filerSample</filter-name>
<filter-class>testFilter.filterSample</filter-class>
<filter>
<filter-mapping>
<filter-name>filerSample</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
另外,你可以为你的Filter配置初始参数,请看下面的代码
<filter>
<filter-name>filerSample</filter-name>
<filter-class>testFilter.filterSample</filter-class>
<init-param>
<param-name>name</param-name>
<param-value>zhang</param-value>
<init-param>
<filter>
<filter-mapping>
<filter-name>filerSample</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
获得这个初始参数的办法是,通过Filter类中定义的filterConfig来获取
filterConfig.getInitParameter(“name”)
另外,request.getRequestURI()函数可以获取请求页面的地址。
一个Filter可以有多个Filter Mapping,另外,一个Web组件也可以配置多个过滤器。这些过滤器按照配置中出现的先后顺序组成一个过滤链。另外,过滤器的url-pattern配置为/*,表示对根目录下的所有文件及其所有下级目录的所有文件过滤。
以下几点是需要特殊说明的:
1) 一个Filter可以配置多个filter-mapping,从而实现对多个url进行过滤
2) 在一个应用程序中,Filter的触发顺序和filter-mapping出现的顺序是一致的.