例如:
服务器 example.com 的路径 /examples下的匹配模式<url-pattern>/status/*</url-pattern> 可有如下匹配:
http ://example.com/examples/status/synopsis
http ://example.com/examples/status/complete?date=today
http ://example.com/examples/status
不匹配:
http ://example.com/examples/server/status
服务器 example.com 的路径 /examples下的匹配模式<url-pattern>*.map</url-pattern> 可有如下匹配:
http ://example.com/examples/US/Oregon/Portland.map
http ://example.com/examples/US/Washington/Seattle.map
http ://example.com/examples/Paris.France.map
不匹配
http ://example.com/examples/US/Oregon/Portland.MAP
//扩展名为大写
http ://example.com/examples/interface/description/mail.mapi
//扩展名是mapi 而不是 map
同一 web.xml文件中的不同的 filter 经常用到同一个 url-pattern 。在这种情况下,能匹配上 request 的每一个filter都会处理此 request。
相 反,在同一个web应用中没有两个servlet会映射到同一个 url-pattern,如果同一 web.xml文件中一个 url-pattern映射到不同的servlet,容器就无法保证对一个 request 调用哪个servlet。不过两个servlet可用部分一致的url-pattern(即/*或 *.extention),这样容器调用哪个servlet由匹配过程决定。
2.2 Servlet 匹配过程
一个request可能匹配多于一个 servlet 映射。容器使用straightforward的匹配过程决定哪个servlet最匹配。匹配过程有四个简单规则:
1〉严格匹配优先于带 * 的匹配;
2〉最长pattern优先于其他pattern;
3〉路径匹配优先于文件类型匹配;
4〉pattern <url-pattern>/</url-pattern> 总是匹配没有其他pattern匹配的request。
例如:
web.xml文件可能将在线目录的首页映射给一个pattern,而将在线目录的查询页映射给另一个pattern :
<servlet-mapping>
<servlet-name>catalogBrowse</servlet-name>
<url-pattern>/Catalog/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>catalogSearch</servlet-name>
<url-pattern>/Catalog/search/*</url-pattern>
</servlet-mapping>
下图描述了匹配过程:由于最长pattern优先于其他pattern,包含/Catalog/search/的URL总是映射到catalogSearch,而不是catalogBrowse。