web.xml中的url-pattern

本文详细解析了web.xml文件中Servlet与Filter的URL匹配规则,包括精确匹配、路径匹配、扩展名匹配及缺省匹配等,阐述了各种匹配方式的特点及优先级。

web.xml文件中,url-pattern有两种,一种是Servlet的,一种是Filter的。常见的用法如下:


         <filter>  
            <filter-name>characterEncodingFilter</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>  
            <init-param>  
                <param-name>forceEncoding</param-name>  
                <param-value>true</param-value>  
            </init-param>  
        </filter>  
        <filter-mapping>  
            <filter-name>characterEncodingFilter</filter-name>  
            <url-pattern>/*</url-pattern>  
        </filter-mapping>  


        <servlet>
           <servlet-name>Spring</servlet-name>
           <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
           <!-- 表示启动容器时初始化该servlet -->
           <init-param>
               <param-name>contextConfigLocation</param-name>
               <param-value>classpath:Spring-servlet.xml</param-value>
           </init-param>
           <load-on-startup>1</load-on-startup>
       </servlet>
       <servlet-mapping>
       <servlet-name>Spring</servlet-name>
           <!-- 表示哪些请求需要交给Spring Web MVC处理,/是用来定义默认servlet映射的。也可以如“*.html”表示拦截所有以html为扩展名的请求 -->
           <url-pattern>/</url-pattern>
       </servlet-mapping>

下面来一个个分析这些url的使用场景吧。

Servlet中的 url-pattern
  • Servlet 2.5开始,一个servlet可以使用多个url-pattern规则,标签声明了与该servlet相应的匹配规则,每个标签代表1个匹配规则;
  • 当servlet容器接收到浏览器发起的一个url请求后,容器会用url减去当前应用的上下文路径,以剩余的字符串作为servlet映射,假如url是http://localhost:8080/appDemo/index.html,其应用上下文是appDemo,容器会将http://localhost:8080/appDemo去掉,用剩下的/index.html部分拿来做servlet的映射匹配;
  • url-pattern映射匹配过程是有 优先顺序 的,而且当有一个servlet匹配成功以后,就不会去理会剩下的servlet了

这里主要值得分析的是第三点,即优先顺序。在这之前,看看有哪些匹配规则。

精确匹配

url-pattern 中配置的项必须与 url 完全精确匹配。例如:

<servlet-mapping>
    <servlet-name>MyServlet</servlet-name>
    <url-pattern>/user/users.html</url-pattern>
    <url-pattern>/index.html</url-pattern>
</servlet-mapping>

http://localhost:8080/appDemo/index.html 会被匹配到MyServlet

路径匹配

“/”字符开头,并以“/*”结尾的字符串用于路径匹配。例如:

<servlet-mapping>
    <servlet-name>MyServlet</servlet-name>
    <url-pattern>/user/*</url-pattern>
</servlet-mapping>

路径以/user/开始,后面的路径可以任意。比如 http://localhost:8080/appDemo/user/users.html

扩展名匹配

 以“*.”开头的字符串被用于扩展名匹配。例如:

<servlet-mapping>
    <servlet-name>MyServlet</servlet-name>
    <url-pattern>*.html</url-pattern>
</servlet-mapping>

则任何扩展名为html的url请求都会匹配,比如 http://localhost:8080/appDemo/user/users.html
注意: 如<url-pattern>/user/*.action</url-pattern>是非法的。路径匹配和扩展匹配不能同时使用。
另外,<url-pattern>/aa/*/bb</url-pattern>是精确匹配,合法,这里的*不是通配的含义

缺省匹配
<servlet-mapping>
    <servlet-name>MyServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
匹配优先级

精确匹配 > 路径匹配 > 扩展名匹配 > 缺省匹配,只要前面有一个匹配成功,就匹配结束。

"/*""/"比较
  • “/*”属于路径匹配,并且可以匹配所有request,由于路径匹配的优先级仅次于精确匹配,所以“/*”会覆盖所有的扩展名匹配,很多404错误均由此引起,所以这是一种特别恶劣的匹配模式,一般只用于filter的url-pattern
  • “/”是servlet中特殊的匹配模式,该模式同样会 匹配所有request,但优先级最低。
  • “/*”“/”均会拦截静态资源的加载,需要特别注意。
Filter中的 url-pattern

其实上面已经把url-pattern 规则都讲完了。
对于filter,不会像servlet 那样只匹配一个servlet,因为filter的集合是一个链,所以只会有处理的顺序不同,而不会出现只选择一个filter。Filter的处理顺序和filter-mapping在web.xml中定义的顺序相同。

本博文参考了 servlet的url-pattern匹配规则

### 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> ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值