servlet路径映射规范(备忘)


一、使用 URL 路径

在收到客户端请求时, web 容器确定转发到哪一个 Web 应用。选择的 Web 应用必须具有最长的上下文路径
匹配请求 URL 的开始。当映射到 Servlet 时, URL 匹配的一部分是上下文。
Web 容器接下来必须用下面描述的路径匹配步骤找出 servlet 来处理请求。
用于映射到 Servlet 的路径是请求对象的请求 URL 减去上下文和路径参数部分。下面的 URL 路径映射规则
按顺序使用。使用第一个匹配成功的且不会进一步尝试匹配:
1. 容器将尝试找到一个请求路径到 servlet 路径的精确匹配。成功匹配则选择该 servlet。
2. 容器将递归地尝试匹配最长路径前缀。这是通过一次一个目录的遍历路径树完成的,使用‘ /’字符作为
路径分隔符。最长匹配确定选择的 servlet。
3. 如果 URL 最后一部分包含一个扩展名(如 .jsp), servlet 容器将视图匹配为扩展名处理请求的 Servlet。
扩展名定义在最后一部分的最后一个‘ .’字符之后。
4. 如果前三个规则都没有产生一个 servlet 匹配,容器将试图为请求资源提供相关的内容。如果应用中定义
了一个“ default” servlet,它将被使用。许多容器提供了一种隐式的 default servlet 用于提供内容。
容器必须使用区分大小写字符串比较匹配。


二、映射规范

在 web 应用部署描述符中,以下语法用于定义映射:
1. 以‘ /’字符开始、以‘ /*’后缀结尾的字符串用于路径匹配。
2. 以‘ *.’开始的字符串用于扩展名映射。
3. 空字符串“”是一个特殊的 URL 模式, 其精确映射到应用的上下文根,即,

http://host:port/<context-root>/

请求形式。在这种情况下,路径信息是‘ /’且 servlet 路径和上下文路径是空字符串(“”)
4. 只包含“ /”字符的字符串表示应用的“ default” servlet。在这种情况下, servlet 路径是请求 URL 减去上下文路径且路径信息是 null。
5. 所以其他字符串仅用于精确匹配。


如果一个有效的 web.xml(在从 fragment 和注解合并了信息后)包含任意的 url-pattern,其映射到多个servlet,那么部署将失败。

猜你喜欢

转载自blog.csdn.net/lianjunzongsiling/article/details/74800072