web.xml中的url-pattern

URL-Pattern详解
本文详细解析了Servlet配置中的URL-Pattern标签使用方法,包括通配符的使用、精确匹配及如何区分静态资源。

标签<url-pattern>

<url-pattern>是我们用Servlet做Web项目时需要经常配置的标签,例:

<servlet>
<servlet-name>index</servlet-name>
<servlet-class>com.we.servlet.IndexServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>index</servlet-name>
<url-pattern>/index</url-pattern>
</servlet-mapping>

当我们在浏览器的地址栏里输入http://localhost:8080/we/index时[假设我部署在webapps目录下的项目名为we]

就会匹配到我们指定的<url-pattern>中,即/index然后一步一步找到对应的<servlet-class>

那我们输入的URL:http://localhost:8080/we/index又是如何与<url-pattern>中的/index匹配的呢?

首先我们要知道URL的组成

http://localhost:8080    我们可以理解为是我们的服务器地址,而该地址之后的部分我们统称为:RequestURI

RequestURI是我们需要重点注意的部分,其又可以分解为几部分

/we  是我们的ServletConext的上下文地址,我们称为ServletContext Path,可以简单理解为部署项目时的webapps目录下的项目名

/index  是我们的Servlet的地址,我们称为Servlet Path,这里就是需要与我们的<url-pattern>匹配的内容

注:在/index后边我们还可以跟其他的信息,例如:/index?name=admin&pass=admin  这是其中一种明文表示的方式

 

标签<url-pattern>中*的使用

我们知道在写<url-pattern>时有一种通配符的使用写法,即*

1.当我使用<url-pattern>/*</url-pattern>时,我们可以匹配所有的请求,即所有的请求都会经过该标签对应的Servlet

此时就需要注意静态资源的请求,因为当我们使用http://localhost:8080/we/login.html时,依然会匹配该Servlet,

而很多静态资源其实是不需要经过Servlet的,例如:js,css,html,jsp,img等静态资源文件,此时就需要在该Servlet中对静态资源做特殊处理

2.如果配有如下两个<url-pattern>标签时,URL地址为http://localhost:8080/we/index时又是如何匹配的呢?

<url-pattern>/index</url-pattern>

<url-pattern>/*</url-pattern>

上边我们已经说过,/*可以匹配所有的请求,而/index也可以匹配我们的URL地址,此时URL地址会自动且优先的进行精确匹配,即/index,

且只匹配一次,也就是说一旦匹配到一个Servlet即执行该Servlet不再对其他Servlet进行匹配,

当我们输入一个http://localhost:8080/we/login时,由于此时匹配不到/login所以只能匹配/*了

3.在Servlet Path部分我们还可以使用更精确的匹配,例如:

<url-pattern>/index/login</url-pattern>匹配http://localhost:8080/we/index/login

<url-pattern>/index/logout</url-pattern>匹配http://localhost:8080/we/index/logout

此时/index/login和/index/logout才是我们的Servlet Path

 4.我们可以通过使用<url-pattern>*.do</url-pattern>来过滤请求,

这样如果我们在页面中的请求中添加后缀名.do就可以避免对静态资源的过滤了,也就不需要对静态资源做特殊处理了

 

注:<url-pattern>/</url-pattern>和<url-pattern>/*</url-pattern>效果是一样的

### web.xml中filter-class报错原因及解决方案 在配置`web.xml`时,如果`<filter-class>`出现报错,通常与以下几种情况有关[^1]: - **路径配置错误**:检查`web.xml`所在的路径是否正确,以及它是否与关联的Web工程根路径一致。例如,在Spring MVC项目中,如果引用了另一个Web工程的`web.xml`文件,可能会导致路径不匹配的问题。 - **DTD或Schema版本问题**:`web.xml`的结构需要严格遵循指定的DTD(Document Type Definition)或Schema版本。如果使用的元素顺序不符合当前版本的要求,则会导致报错。例如,`<web-app>`标签下的子元素必须严格按照定义的顺序排列[^3]。 - **拼写错误或语法问题**:确保`<filter-class>`及其父标签`<filter>`的书写正确无误。任何多余的空格、未闭合的标签或错误的命名都会引发解析错误。 #### 解决方案 以下是解决`<filter-class>`报错的常见方法: 1. **验证`web.xml`的头信息**: 确保`web.xml`文件的头信息正确声明了所使用的DTD或Schema版本。例如,对于Servlet 3.0规范,可以使用以下声明: ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> </web-app> ``` 如果使用的版本不匹配,可能导致某些标签无效。 2. **检查`<filter>`和`<filter-mapping>`的配置**: 确保`<filter>`和`<filter-mapping>`的配置完整且顺序正确。以下是一个标准的`filter`配置示例: ```xml <filter> <filter-name>exampleFilter</filter-name> <filter-class>com.example.ExampleFilter</filter-class> </filter> <filter-mapping> <filter-name>exampleFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 3. **清理并重新构建项目**: 在IDE(如IntelliJ IDEA或Eclipse)中,尝试清理并重新构建项目以确保所有资源文件被正确加载。有时,缓存问题可能导致`web.xml`中的错误未能及时更新[^2]。 4. **检查外部依赖冲突**: 如果项目中存在多个Web模块或依赖冲突,可能会导致`web.xml`解析异常。确认是否有其他模块的`web.xml`文件被错误引用。 5. **参考外文解决方案**: 根据类似问题的解决经验,有时需要调整`web.xml`中特定标签的位置或内容。例如,将某些代码块移动到`<jsp-config>`标签内可能不会生效,但调整整体结构可能会解决问题[^2]。 --- ### 示例代码 以下是一个完整的`web.xml`配置示例,展示如何正确配置`<filter>`和`<filter-class>`: ```xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" version="3.0"> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app> ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值