優雅REST風格的資源URL不希望帶 .html 或 .do 等字尾.由于早期的Spring MVC不能很好地處理靜态資源,是以在web.xml中配置DispatcherServlet的請求映射,往往使用 *.do 、 *.xhtml等方式。這就決定了請求URL必須是一個帶字尾的URL,而無法采用真正的REST風格的URL。
如果将DispatcherServlet請求映射配置為"/",則Spring MVC将捕獲Web容器所有的請求,包括靜态資源的請求,Spring MVC會将它們當成一個普通請求處理,是以找不到對應處理器将導緻錯誤。
如何讓Spring架構能夠捕獲所有URL的請求,同時又将靜态資源的請求轉由Web容器處理,是可将DispatcherServlet的請求 映射配置為"/"的前提。由于REST是Spring3.0最重要的功能之一,是以Spring團隊很看重靜态資源處理這項任務,給出了堪稱經典的兩種解 決方案。
先調整web.xml中的DispatcherServlet的配置,使其可以捕獲所有的請求:
<code><servlet></code>
<code> </code><code><servlet-name>springMVC</servlet-name></code>
<code> </code><code><servlet-</code><code>class</code><code>>org.springframework.web.servlet.DispatcherServlet</servlet-</code><code>class</code><code>></code>
<code> </code><code><load-on-startup></code><code>1</code><code></load-on-startup></code>
<code> </code><code></servlet></code>
<code> </code><code><servlet-mapping></code>
<code> </code><code><url-pattern>/</url-pattern></code>
<code> </code><code></servlet-mapping></code>
通過上面url-pattern的配置,所有URL請求都将被Spring MVC的DispatcherServlet截獲。
采用<mvc:default-servlet-handler />
在springMVC-servlet.xml中配置<mvc:default-servlet-handler />後,會在Spring MVC上下文中定義一個 org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler, 它會像一個檢查員,對進入DispatcherServlet的URL進行篩查,如果發現是靜态資源的請求,就将該請求轉由Web應用伺服器預設的 Servlet處理,如果不是靜态資源的請求,才由DispatcherServlet繼續處理。
一般Web應用伺服器預設的Servlet名稱是"default",是以DefaultServletHttpRequestHandler可 以找到它。如果你所有的Web應用伺服器的預設Servlet名稱不是"default",則需要通過default-servlet-name屬性顯示 指定:
<mvc:default-servlet-handler default-servlet-name="所使用的Web伺服器預設使用的Servlet名稱" />
采用<mvc:resources />
<mvc:default-servlet-handler />将靜态資源的處理經由Spring MVC架構交回Web應用伺服器處理。而<mvc:resources />更進一步,由Spring MVC架構自己處理靜态資源,并添加一些有用的附加值功能。
首先,<mvc:resources />允許靜态資源放在任何地方,如WEB-INF目錄下、類路徑下等,你甚至可以将JavaScript等靜态檔案打到JAR包中。通過 location屬性指定靜态資源的位置,由于location屬性是Resources類型,是以可以使用諸如"classpath:"等的資源字首指 定資源位置。傳統Web容器的靜态資源隻能放在Web容器的根路徑下,<mvc:resources />完全打破了這個限制。
其次,<mvc:resources />依據目前著名的Page Speed、YSlow等浏覽器優化原則對靜态資源提供優化。你可以通過cacheSeconds屬性指定靜态資源在浏覽器端的緩存時間,一般可将該時間 設定為一年,以充分利用浏覽器端的緩存。在輸出靜态資源時,會根據配置設定好響應封包頭的Expires 和 Cache-Control值。
在接收到靜态資源的擷取請求時,會檢查請求頭的Last-Modified值,如果靜态資源沒有發生變化,則直接傳回303相應狀态碼,提示用戶端使用浏覽器緩存的資料,而非将靜态資源的内容輸出到用戶端,以充分節省帶寬,提高程式性能。
在springMVC-servlet中添加如下配置:
<mvc:resources location="/,classpath:/META-INF/publicResources/" mapping="/resources/**"/>
以上配置将Web根路徑"/"及類路徑下 /META-INF/publicResources/ 的目錄映射為/resources路徑。假設Web根路徑下擁有images、js這兩個資源目錄,在images下面有bg.gif圖檔,在js下面有 test.js檔案,則可以通過 /resources/images/bg.gif 和 /resources/js/test.js 通路這二個靜态資源。
假設WebRoot還擁有images/bg1.gif 及 js/test1.js,則也可以在網頁中通過 /resources/images/bg1.gif 及 /resources/js/test1.js 進行引用
或者:
<code>web.xml裡添加如下的配置</code>
<code><servlet-mapping></code>
<code> </code><code><servlet-name></code><code>default</code><code></servlet-name></code>
<code> </code><code><url-pattern>*.css</url-pattern></code>
<code></servlet-mapping></code>
<code> </code><code><servlet-name></code><code>default</code><code></servlet-name></code>
<code> </code><code><url-pattern>*.gif</url-pattern></code>
<code> </code>
<code> </code><code><url-pattern>*.jpg</url-pattern></code>
<code> </code><code><url-pattern>*.js</url-pattern></code>
Spring 攔截器,對于mapping path符合的url進行攔截,excludeURIS對于的不攔截
<code><mvc:interceptors></code>
<code> </code><code><mvc:interceptor></code>
<code> </code><code><mvc:mapping path=</code><code>"/student/**"</code><code>/></code>
<code> </code><code><mvc:mapping path=</code><code>"/courses"</code><code>/></code>
<code> </code><code><bean </code><code>class</code><code>=</code><code>"com.jayung.curriculum.web.interceptor.LoginInterceptor"</code><code>/></code>
<code> </code><code></mvc:interceptor></code>
<code> </code><code><mvc:mapping path=</code><code>"/console/**"</code><code>/></code>
<code> </code><code><bean </code><code>class</code><code>=</code><code>"com.jayung.curriculum.web.interceptor.ConsoleInterceptor"</code><code>></code>
<code> </code><code><property name=</code><code>"excludeURIs"</code><code>></code>
<code> </code><code><list></code>
<code> </code><code><value>/console</value></code>
<code> </code><code><value>/console/login</value></code>
<code> </code><code></list></code>
<code> </code><code></property></code>
<code> </code><code></bean></code>
<code> </code><code></mvc:interceptors></code>
<code></code>
本文轉自yunlielai51CTO部落格,原文連結:http://blog.51cto.com/4925054/1715301,如需轉載請自行聯系原作者