基础7——url-pattern匹配规则

首先需要明确几容易混淆的规则:

1.servlet容器中的匹配规则既不是简单的通配,也不是正则表达式,而是特定的规则。所以不要用通配符或者正则表达式的匹配规则来看待servlet的url-pattern。

2.Servlet 2.5开始,一个servlet可以使用多个url-pattern规则,标签声明了与该servlet相应的匹配规则,每个标签代表1个匹配规则;

3.当servlet容器接收到浏览器发起的一个url请求后,容器会用url减去当前应用的上下文路径,以剩余的字符串作为servlet映射,假如url是http://localhost:8080/appDemo/index.html,其应用上下文是appDemo,容器会将http://localhost:8080/appDemo去掉,用剩下的/index.html部分拿来做servlet的映射匹配

4.url-pattern映射匹配过程是有优先顺序的,而且当有一个servlet匹配成功以后,就不会去理会剩下的servlet了。

说明:

1、不能将两个Servlet映射到同一个url-pattern,Tomcat会报错;

2、

HelloServlet

/user/hi

与:

 

HelloServlet

/user/*

如果URL为http://localhost:8080/demo/user/hi 优先精确匹配,即匹配HelloServlet

 

 

一、四种匹配规则

1 精确匹配

  中配置的项必须与url完全精确匹配。

注:/user/*/hi 这里的*不是通配符,是精确匹配

2 扩展名匹配

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

注:/user/*.html 错误,会产生IllegalArgumentException

3 路径匹配

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

注:/user/*/hi 这里不是路径匹配,是精确匹配

4 缺省匹配

/

 

 

二、匹配顺序

1 精确匹配

2 路径匹配,先最长路径匹配,再最短路径匹配

3 扩展名匹配

4 缺省匹配,以上都找不到servlet,就用默认的servlet,配置为/

 

 

 

三、需要注意的问题

1 路径匹配和扩展名匹配无法同时设置

  匹配方法只有三种,要么是路径匹配(以“/”字符开头,并以“/*”结尾),要么是扩展名匹配(以“*.”开头),要么是精确匹配,三种匹配方法不能进行组合,不要想当然使用通配符或正则规则。

  如/user/*.action是非法的

  另外注意:/aa/*/bb是精确匹配,合法,这里的*不是通配的含义

2 "/*"和"/"含义并不相同

l  “/*”属于路径匹配,并且可以匹配所有request,由于路径匹配的优先级仅次于精确匹配,所以“/*”会覆盖所有的扩展名匹配,很多404错误均由此引起,所以这是一种特别恶劣的匹配模式,一般只用于filter的url-pattern

l  “/”是servlet中特殊的匹配模式,切该模式有且仅有一个实例,优先级最低,不会覆盖其他任何url-pattern,只是会替换servlet容器的内建default servlet ,该模式同样会匹配所有request。

l  配置“/”后,一种可能的现象是myServlet会拦截诸如http://localhost:8080/appDemo/user/addUser.action、http://localhost:8080/appDemo/user/updateUser的格式的请求,但是并不会拦截http://localhost:8080/appDemo/user/users.jsp、http://localhost:8080/appDemo/index.jsp,这是应为servlet容器有内置的“*.jsp”匹配器,而扩展名匹配的优先级高于缺省匹配,所以才会有上述现象。

转载于:https://www.cnblogs.com/lpd1/p/7711419.html

你可能感兴趣的:(基础7——url-pattern匹配规则)