servlet容器对url的匹配规则(web.xml中的url-pattern映射规则)

本文深入解析Servlet容器如何根据URL匹配Servlet及Filter,并详细介绍URL模式(url-pattern)的规则,包括精确路径匹配、最长路径匹配等,帮助理解Servlet的工作原理。

Servlet和filter是J2EE开发中常用的技术,使用方便,配置简单。servlet和filter中的url-pattern有一些文章在里面的,总结了一些东西,以免遇到问题又要浪费时间。 
   

一,servlet容器对url的匹配过程: 

当 一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url,比如我访问的是 http://localhost/test/aaa.html,我的应用上下文是test,容器会将http://localhost/test去掉, 剩下的/aaa.html部分拿来做servlet的映射匹配。这个映射匹配过程是有顺序的,而且当有一个servlet匹配成功以后,就不会去理会剩下 的servlet了(filter不同,后文会提到)。其匹配规则和顺序如下: 

1.     精确路径匹配。例子:比如servletA 的url-pattern为 /test,servletB的url-pattern为 /* ,这个时候,如果我访问的url为http://localhost/test ,这个时候容器就会先进行精确路径匹配,发现/test正好被servletA精确匹配,那么就去调用servletA,也不会去理会其他的 servlet了。 

2.     最长路径匹配。例子:servletA的url-pattern为/test/*,而servletB的url-pattern为/test/a/*,此 时访问http://localhost/test/a时,容器会选择路径最长的servlet来匹配,也就是这里的servletB。 

3.     扩展匹配,如果url最后一段包含扩展,容器将会根据扩展选择合适的servlet。例子:servletA的url-pattern:*.action 

4.     如果前面三条规则都没有找到一个servlet,容器会根据url选择对应的请求资源。如果应用定义了一个default servlet,则容器会将请求丢给default servlet(什么是default servlet?后面会讲)。 

     根据这个规则表,就能很清楚的知道servlet的匹配过程,所以定义servlet的时候也要考虑url-pattern的写法,以免出错。 

      对于filter,不会像servlet那样只匹配一个servlet,因为filter的集合是一个链,所以只会有处理的顺序不同,而不会出现只选择一 个filter。Filter的处理顺序和filter-mapping在web.xml中定义的顺序相同。 
   

二,url-pattern详解 

         在web.xml文件中,以下语法用于定义映射: 

l. 以”/’开头以”/*”结尾的是用来做路径映射的。 

2. 以前缀”*.”开头的是用来做扩展映射的。 

3. “/” 是用来定义default servlet映射的。 

4. 剩下的都是用来定义详细映射的。比如: /aa/bb/cc.action 

所以,为什么定义”/*.action”这样一个看起来很正常的匹配会错?因为这个匹配即属于路径映射,也属于扩展映射,导致容器无法判断

 

另外,关于url-pattern映射之后, request的servletContextPath , ServletPath , PathInfo 情况,可参照下面链接的文章

http://blog.youkuaiyun.com/cooljia/article/details/187882

<think>好的,我现在需要帮助用户解决他们在使用IntelliJ IDEA和Tomcat时遇到的404错误问题,特别是关于target生成的web.xml中<servlet-name>SpringMVC</servlet-name>报应具有映射错误的情况。首先,我需要理清用户的问题究竟是什么。 用户提到在target生成的web.xml中,<servlet-name>SpringMVC</servlet-name>报应具有映射错误。这里的“报应具有映射错误”可能是指配置错误导致的异常或错误提示,比如Servlet名称与映射匹配,或者配置不正确。我需要先理解常见的Spring MVC配置问题,以及web.xmlservletservlet-mapping的关系。 首先,考虑用户的项目结构是否正确。用户可能在使用Maven项目,web.xml的位置是否正确,例如是否在src/main/webapp/WEB-INF目录下。如果web.xml的位置不对,Maven在构建时可能不会正确打包,导致生成的web.xml不符合预期。另外,用户可能手动修改了生成的web.xml,或者存在多个web.xml文件冲突的情况。 接下来,检查servletservlet-mapping的配置是否正确。在Spring MVC中,通常需要配置DispatcherServlet,并指定servlet-name和对应的映射路径。例如: <servlet> <servlet-name>SpringMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>SpringMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> 用户的问题可能是servlet-name在servletservlet-mapping之间不匹配,或者url-pattern配置错误。比如,如果servlet-name在servlet-mapping中写成了不同的名称,或者url-pattern没有正确设置,导致DispatcherServlet无法处理请求,从而引发404错误。 另外,需要注意是否缺少必要的依赖。例如,Spring MVC的相关依赖是否在pom.xml中正确引入,特别是spring-webmvc的依赖。如果依赖缺失,可能导致DispatcherServlet类无法找到,从而引发ClassNotFoundException,最终导致应用部署失败,出现404错误。 此外,还要考虑配置文件的位置和内容是否正确。例如,contextConfigLocation参数指向的spring-mvc.xml是否存在,并且是否正确配置了组件扫描、视图解析器等。如果配置文件路径错误,Spring容器无法初始化,同样会导致请求无法处理。 用户提到的问题是在target生成的web.xml中出现的错误,这可能意味着在构建过程中,web.xml被修改或生成不正确。需要检查项目的构建配置,尤其是Maven的pom.xml中是否有正确的资源过滤或配置插件,确保web.xml被正确复制到target目录。同时,如果用户使用了注解配置(如Spring Boot),可能需要检查是否同时存在web.xml和注解配置导致冲突。 另外,Tomcat的部署配置也需要检查。在IntelliJ IDEA中,Tomcat的部署工件是否正确设置为war exploded,并且应用程序上下文路径是否正确。如果上下文路径设置错误,用户访问的URL可能不正确,导致404错误。 还有可能的问题是缓存或旧版本的残留。有时候,即使代码正确,Tomcat可能仍然加载旧的配置或类文件。需要清理Tomcat的工作目录,重新构建项目,并重启Tomcat以确保所有更改生效。 总结下来,用户的可能问题点包括: 1. web.xmlservlet-name在servletservlet-mapping中的不一致。 2. 缺少必要的Spring MVC依赖。 3. 配置文件路径错误或内容不正确。 4. 构建过程中web.xml未正确生成或复制到target目录。 5. Tomcat配置错误,如上下文路径或部署工件设置问题。 6. 缓存或旧文件残留导致配置未生效。 接下来,我需要一步步引导用户检查这些可能的错误点,并提供具体的解决步骤。需要确保回答结构清晰,分步骤说明,每个步骤包含具体的检查点和解决方法。同时,要使用中文,保持口语化,避免使用专业术语过多,但必要时仍需准确描述技术细节。 在回答中,需要提醒用户检查servlet-name是否一致,确认依赖是否存在,验证配置文件路径,清理构建目录和Tomcat工作缓存,以及重新部署项目。此外,建议用户提供更多信息,如具体的错误日志、项目结构截图等,以便更精准地定位问题。</think>当在 `web.xml` 中遇到 `<servlet-name>SpringMVC</servlet-name>` 的映射错误时,通常是由于 **Servlet名称与映射配置不匹配** 或 **Spring MVC核心配置缺失** 导致。以下是详细排查步骤: --- ### **第一步:检查 `<servlet>` 和 `<servlet-mapping>` 的匹配性** 1. **名称必须一致** - 确保 `<servlet>` 标签中的 `<servlet-name>` 与 `<servlet-mapping>` 标签中的 `<servlet-name>` **完全一致**(包括大小写)。 - 错误示例: ```xml <!-- Servlet定义 --> <servlet> <servlet-name>SpringMVC</servlet-name> <!-- 正确名称 --> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> </servlet> <!-- 映射定义 --> <servlet-mapping> <servlet-name>springmvc</servlet-name> <!-- 错误:名称大小写不一致 --> <url-pattern>/</url-pattern> </servlet-mapping> ``` 2. **检查 `<url-pattern>` 的合理性** - Spring MVC 的 `DispatcherServlet` 通常映射到根路径 `/` 或指定后缀(如 `*.do`)。 - 错误示例: ```xml <url-pattern>/spring/*</url-pattern> <!-- 可能导致控制器路径匹配失败 --> ``` --- ### **第二步:验证 `DispatcherServlet` 配置** 1. **确认类路径正确** - `<servlet-class>` 必须指向 `DispatcherServlet` 的全限定类名: ```xml <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> ``` - 若未正确引入Spring依赖,会报 `ClassNotFoundException`。 2. **检查初始化参数 `contextConfigLocation`** - 如果未显式指定配置文件路径,默认会加载 `/WEB-INF/[servlet-name]-servlet.xml`。 - 推荐显式配置: ```xml <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring-mvc.xml</param-value> <!-- 指向实际配置文件 --> </init-param> ``` --- ### **第三步:检查依赖和配置文件** 1. **确保引入Spring MVC依赖** - 在 `pom.xml` 中必须包含以下依赖(以Maven为例): ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.3.18</version> </dependency> ``` - 未添加此依赖会导致 `DispatcherServlet` 类无法加载。 2. **验证Spring配置文件的存在性** - 确保 `spring-mvc.xml`(或自定义名称)位于 `WEB-INF` 目录下,并包含以下基本配置: ```xml <!-- 启用组件扫描 --> <context:component-scan base-package="com.example.controller" /> <!-- 注解驱动 --> <mvc:annotation-driven /> <!-- 视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> ``` --- ### **第四步:排查构建和部署问题** 1. **清理并重新生成项目** - 执行 `mvn clean install`(Maven项目)或手动删除 `target` 目录,确保构建时 `web.xml` 正确复制到输出目录。 2. **检查IDEA的Artifact配置** - 进入 `File → Project Structure → Artifacts`,确认 `WEB-INF` 目录下包含 `web.xml` 和 `spring-mvc.xml`。 --- ### **第五步:查看日志定位具体错误** - **Tomcat启动日志**:在IDEA控制台中查找以下关键错误: - `NoSuchBeanDefinitionException` → 控制器未扫描到 - `FileNotFoundException` → 配置文件路径错误 - `HTTP Status 404 – Not Found` → URL映射到控制器方法 --- ### **总结解决方案** $$ \begin{aligned} 1. &\text{检查} \ <servlet-name> \text{是否一致} → \text{修正名称匹配} \\ 2. &\text{确认} \ DispatcherServlet \ \text{类路径和配置文件} → \text{补充依赖或修复路径} \\ 3. &\text{清理并重新构建项目} → \text{确保资源文件正确打包} \end{aligned} $$ **附加提醒**: - 如果使用 **Spring Boot**,通常不需要手动配置 `web.xml`,建议改用注解方式(如 `@SpringBootApplication` + `SpringApplication.run()`)。 - 若问题仍未解决,请提供以下信息: - `web.xml` 完整内容 - `pom.xml` 中的依赖列表 - Tomcat日志中的具体错误片段
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值