1. web.xml中url-pattern配置
url-pattern为/
使用SpringMVC的框架时,需要在web.xml
配置前端控制器DispatcherServlet
,配置为:
<!-- 配置前端控制器 --> <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath: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>
url-pattern为/*
我们需要使用过滤器时,需要在web.xml
中进行注册。以处理中文乱码的过滤器CharacterEncodingFilter
为例,配置为:
<!-- 处理中文乱码问题 注:一定要放到所有过滤器之前--> <filter> <filter-name>CharacterEncodingFilter</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> <init-param> <param-name>forceRequestEncoding</param-name> <param-value>true</param-value> </init-param> <init-param> <param-name>forceResponseEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
url-pattern为*.do
使用Struts框架时,需要在web.xml中配置控制中心ActionServlet
的拦截规则:
<servlet> <servlet-name>action</servlet-name> <servlet-class>org.apache.struts.action.ActionServlet</servlet-class> <init-param> <param-name>config</param-name> <param-value>/WEB-INF/struts-config.xml</param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>3</param-value> </init-param> <init-param> <param-name>application</param-name> <param-value>ApplicationResources</param-value> </init-param> <load-on-startup>3</load-on-startup> </servlet> <servlet-mapping> <servlet-name>action</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
总结说明
-
url-pattern
的配置/
是用来指定默认Servlet(即default servlet,或者叫缺省Servlet)的。在tomcat的
conf/web.xml
中,定义了默认的Servlet:<!-- The default servlet for all web applications, that serves static --> <!-- resources. It processes all requests that are not mapped to other --> <!-- servlets with servlet mappings (defined either here or in your own --> <!-- web.xml file). This servlet supports the following initialization --> <!-- parameters (default values are in square brackets): --> <servlet> <servlet-name>default</servlet-name> <servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>listings</param-name> <param-value>false</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
如果我们在项目中配置了
/
,是会覆盖掉tomcat中的default servlet的。其实/
和/*
都可以匹配所有的请求资源,但其匹配的优先顺序是不同的。/
在所有的匹配路径中,优先级最低,即当别的路径都无法匹配时,/
所匹配的缺省Servlet才会进行相应的请求资源处理。而/*
匹配的优先级是高于/
和*.xx
的路径的(如*.do
,*.jsp
等路径)。 -
url-pattern
的配置/*
表示拦截所有请求 -
url-pattern
的配置*.do
表示拦截以.do
结尾的请求
2. SpringMVC中Controller拦截规则
SpringMVC的Controller注解@RequestMapping
的匹配规则是Ant风格通配符
*
表示匹配0或者任意数量的字符**
表示匹配0或者更多的目录?
表示匹配任何单字符
最长匹配原则:当请求路径匹配多个模式时,将会按照优先级
? > * > **
来匹配
简单的例子:
路径 | 说明 |
---|---|
@RequestMapping(path = "/request/*") | /request/a、/request/b、/request/ |
@RequestMapping(path = "/requst/**") | /request/a、/request/a/b、/request/a/b/c |
3. 文件匹配
文件匹配与上述第2点是一样的,遵循Ant风格通配符
比如配置MyBatis映射器XML文件路径时:
<!-- 配置MyBatis --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <!-- 指定MyBatis 的 XML 配置文件路径 --> <property name="configLocation" value="classpath:mybatis.xml"/> <!-- 指定映射器 XML 文件路径 --> <property name="mapperLocations" value="classpath:mapper/**/*.xml"/> </bean>
参考文章
servlet与filter的url-pattern设置方式及映射规则
来源:https://www.cnblogs.com/lyldelove/p/12639255.html