web.xml中filter的类型

本文详细介绍了从J2EE1.3开始加入的Servlet 2.3规范中的过滤器支持,包括request过滤器、forward过滤器、include过滤器以及error过滤器的工作方式,并解释了它们如何在不同场景下截取、转发和处理HTTP请求。

从J2EE1.3开始,Servlet2.3规范中加入了对过滤器的支持。过滤器能够对目标资源的请求和响应进行截取。过滤器的工作方式分为四种,下面让我们分别来看看这四种过滤器的工作方式:
1、request过滤器
    这种过滤器的工作方式比较简单,大家也经常遇到,如下图所示:
web.xml中filter的用法以下是web.xml文件配置方式:
<filter>
    <filter-name>myFilter</filter-name>
    <filter-class>xx.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源一</servlet-name>
</filter-mapping>
下面我们更改一下web.xml文件的配置,如下方式:
<filter>
    <filter-name>myFilter</filter-name>
    <filter-class>xx.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源一</servlet-name>
</filter-mapping>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源二</servlet-name>
</filter-mapping>
也就是说此过滤器对目标资源一和目标资源二都进行过滤,然后当目标资源一被访问的时候我们将请求转发给目标资源二,那么这个时候过滤器是怎么工作的呢?如下图所示:
    我们可以看到,当我们访问目标资源一时过滤器截取了请求,然后再转发给目标资源一,然后再转发给目标资源二,从图中我们可以看到过滤器没有截取转发到目标资源二的请求,但是我们已经在web.xml文件中配置了该过滤器对目标资源二的过滤,为什么又没有起到过滤作用呢?
    答案就在于,目标资源一是客户端直接访问,而目标资源二是被转发过来的,这时过滤器就不能过滤目标资源二。如果你直接访问目标资源二,你会发现该过滤器起到了作用?
    我们上面的web.xml文件配置与以下方式等价:
<filter>myFilter</filter>
    <filter-name>myFilter</filter-name>
    <filter-class>xx.MyFilter</filte-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源一</servlet-name>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源二</servlet-name>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
这种方式的配置,说明只有直接访问该目标资源时该过滤器才会起作用,对转发到该目标资源的请求将忽略不处理。
    那如果我想对转发到目标资源二的请求进行过滤,那怎么办呢?答案见,下一种过滤器,forward过滤器。


2、forward过滤器
    我们将web.xml文件的配置修改如下:
<filter>myFilter</filter>
    <filter-name>myFilter</filter-name>
    <filter-class>xx.MyFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源一</servlet-name>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源二</servlet-name>
<dispatcher>FORWARD</dispatcher>
</filter-mapping>
工作方式如下图所示:
    我们看对目标资源二过滤的配置方式,这时过滤方式为forward,也就是说对转发到目标资源二的请求过滤,如果直接访问目标资源二,过滤器将不起作用。


3、include过滤器
    理解了forward过滤器之后,include过滤器就不难理解了。以下方式:
<filter-mapping>
<filter-name>myFilter</filter-name>
<servlet-name>目标资源二</servlet-name>
<dispatcher>INCLUDE</dispatcher>
</filter-mapping>
    此表示对包含了目标资源二的请求过滤,如果直接访问目标资源二,则此过滤器将不起作用。
    include包含以下语句:
    在JSP页面中的动作:<jsp:include page=.......
    在Java代码中的request.getRequestDispatcher("....").include
    注意:如果目标资源一通过<%@ include file="目标资源二"%>指令包含,这时此过滤器不工作。后面给大家介绍指令包含和动作包含的区别。


4、error过滤器
    当我们访问一个web目标资源时,如果服务器没有找到该目标资源,那么服务器就会给出一个404错误代码。如果我们给404错误代码定义一个页面,那么当404错误发生时就会调用该页面,请看以下web.xml文件的配置:
<filter-mapping>
<filter-name>myFilter</filter-name>
<url-pattern>/error.jsp</url-pattern>
<dispatcher>ERROR</dispatcher>
</filter-mapping>
<error-page>
    <error-code>404</error-code>
    <location>/error.jsp</location>
</error-page>
    当我们访问一个不存在的文件时,就会访问error.jsp,但是配置了过滤器对错误页面进行过滤,所以过滤器先接受到请求,然后再转发给error.jsp。

    如果我们访问一个已经存在的页面,会不会调用error.jsp呢?如果这个页面中有response.sendError(404,"出错了!");那么该错误页面仍然会被调用,过滤器也会工作。


本文转自:http://blog.sina.com.cn/s/blog_4e82fae20100fdqr.html

### web.xmlfilter-class报错原因及解决方案 在配置`web.xml`时,如果`<filter-class>`出现报错,通常与以下几种情况有关[^1]: - **路径配置错误**:检查`web.xml`所在的路径是否正确,以及它是否与关联的Web工程根路径一致。例如,在Spring MVC项目中,如果引用了另一个Web工程的`web.xml`文件,可能会导致路径不匹配的问题。 - **DTD或Schema版本问题**:`web.xml`的结构需要严格遵循指定的DTD(Document Type Definition)或Schema版本。如果使用的元素顺序不符合当前版本的要求,则会导致报错。例如,`<web-app>`标签下的子元素必须严格按照定义的顺序排列[^3]。 - **拼写错误或语法问题**:确保`<filter-class>`及其父标签`<filter>`的书写正确无误。任何多余的空格、未闭合的标签或错误的命名都会引发解析错误。 #### 解决方案 以下是解决`<filter-class>`报错的常见方法: 1. **验证`web.xml`的头信息**: 确保`web.xml`文件的头信息正确声明了所使用的DTD或Schema版本。例如,对于Servlet 3.0规范,可以使用以下声明: ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> </web-app> ``` 如果使用的版本不匹配,可能导致某些标签无效。 2. **检查`<filter>`和`<filter-mapping>`的配置**: 确保`<filter>`和`<filter-mapping>`的配置完整且顺序正确。以下是一个标准的`filter`配置示例: ```xml <filter> <filter-name>exampleFilter</filter-name> <filter-class>com.example.ExampleFilter</filter-class> </filter> <filter-mapping> <filter-name>exampleFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 3. **清理并重新构建项目**: 在IDE(如IntelliJ IDEA或Eclipse)中,尝试清理并重新构建项目以确保所有资源文件被正确加载。有时,缓存问题可能导致`web.xml`中的错误未能及时更新[^2]。 4. **检查外部依赖冲突**: 如果项目中存在多个Web模块或依赖冲突,可能会导致`web.xml`解析异常。确认是否有其他模块的`web.xml`文件被错误引用。 5. **参考外文解决方案**: 根据类似问题的解决经验,有时需要调整`web.xml`中特定标签的位置或内容。例如,将某些代码块移动到`<jsp-config>`标签内可能不会生效,但调整整体结构可能会解决问题[^2]。 --- ### 示例代码 以下是一个完整的`web.xml`配置示例,展示如何正确配置`<filter>`和`<filter-class>`: ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app> ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值