【Servlet】web.xml中url-pattern的用法

目录结构:

contents structure [+]

一.url-pattern的三种写法

  1. 精确匹配。以"/"开头,加上servlet名称。
    Java代码 
    1. /ad  
     
  2. 路径匹配。以"/"开头,加上通配符"*"。
    Java代码 
    1. /*  
     
  3. 扩展名匹配。以通配符"*"开头,加上扩展名。
    Java代码 
    1. *.action  
     

二.servlet匹配规则

  1. 先精确匹配,再路径匹配。servlet-mapping1:<url-pattern>/ad</url-pattern>,servlet-mapping2:<url-pattern>/*</url-pattern>。当一个请求http://localhost:8080/ad来的时候,servlet-mapping1匹配到,不再用servlet-mapping2匹配。
  2. 路径匹配的时候,先最长路径匹配,再最短路径匹配。servlet-mapping1:<url-pattern>/ad/uplaod.jsp</url-pattern>,servlet-mapping2:<url-pattern>/ad/*</url-pattern>。当一个请求http://localhost:8080/ad/upload.jsp来的时候,servlet-mapping1匹配到,不再用servlet-mapping2匹配。
  3. 至于扩展名匹配,就是单独于精确匹配和匹配的一类了。struts2的扩展名就是.action,所以http://localhost:8080/ad.action会被servlet-mapping:<url-pattern>*.action</url-pattern>匹配到。
  4. 以上都找不到servlet,就用默认的servlet,配置为<url-pattern>/</url-pattern>。

三. filter匹配规则

    1. 顺着web.xml定义的filter顺序匹配,匹配到了就开始filter。
    2. 有几个就匹配几次filter几次。
          <filter>  
              <filter-name>encodeFilter</filter-name>  
              <filter-class>com.skylark.common.util.EncodeFilter</filter-class>  
          </filter>  
          <filter-mapping>  
              <filter-name>encodeFilter</filter-name>  
              <url-pattern>/*</url-pattern>  
          </filter-mapping>  
        
          <filter>  
              <filter-name>initSessionFilter</filter-name>  
              <filter-class>com.skylark.service.servlet.InitSessionFilter</filter-class>  
          </filter>  
          <filter-mapping>  
              <filter-name>initSessionFilter</filter-name>  
              <url-pattern>/*</url-pattern>  
          </filter-mapping>

      任何请求过来的时候,都会先encode,然后initSession。

四,语法错误的后果

如果匹配符出现语法错误,那么项目是不能够发布的。笔者的服务器报错了如下的错误:

Server Tomcat v8.5 Server at localhost failed to start.

五,原文链接

点我查看原文

原文地址:https://www.cnblogs.com/HDK2016/p/6226960.html