1. web.xml中url pattern配置 url pattern為/ 使用SpringMVC的框架時,需要在 配置前端控制器 ,配置為: url pattern為/ 我們需要使用過濾器時,需要在 中進行註冊。以處理中文亂碼的過濾器 為例,配置為: url pattern為 .do 使用Str ...
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設置方式及映射規則