SPRING-MVC 訪問靜態檔案, 如 jpg/js/css,為了忽略springmvc的過濾匹配__js

來源:互聯網
上載者:User
下面講了一大堆:我解決的方法是web.xml中加入了下面代碼就可以訪問靜態資源檔案了,不然他會老匹配
    <servlet-name>default</servlet-name>    <url-pattern>*.JPG</url-pattern></servlet-mapping>



SpringMVC訪問靜態資源可能會存在找不到資源的問題。 
1、如果只配置攔截類似於*.do格式的url,則對靜態資源的訪問是沒有問題的,如下: 
<!-- SpringMVC核心分發器 -->
    <servlet> 
        <servlet-name>dispatcherServlet</servlet-name> 
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
        <init-param> 
            <param-name>contextConfigLocation</param-name> 
            <param-value>classpath*:config/dispatcher-servlet.xml</param-value> 
        </init-param> 
        <load-on-startup>1</load-on-startup> 
    </servlet> 
    <!-- 映射*.do的請求 -->
    <servlet-mapping> 
        <servlet-name>dispatcherServlet</servlet-name> 
        <url-pattern>*.do</url-pattern> 
    </servlet-mapping> 複製代碼 2、如果配置攔截了所有的請求,如下:
<!-- SpringMVC核心分發器 -->
    <servlet> 
        <servlet-name>dispatcherServlet</servlet-name> 
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
        <init-param> 
            <param-name>contextConfigLocation</param-name> 
            <param-value>classpath*:config/dispatcher-servlet.xml</param-value> 
        </init-param> 
        <load-on-startup>1</load-on-startup> 
    </servlet> 
    <!-- 映射所有的請求 -->
    <servlet-mapping> 
        <servlet-name>dispatcherServlet</servlet-name> 
        <url-pattern>/</url-pattern> 
    </servlet-mapping> 複製代碼 通過上面url-pattern的配置,所有URL請求都將被Spring MVC的DispatcherServlet截獲。這樣的配置,會造成js檔案、css檔案、圖片檔案等靜態資源無法訪問。 

解決方案: 
1.採用<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名稱" /> 複製代碼 2.採用<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 進行引用。 

也可以簡單配置WEB-INF/spring-servlet.xml如下: 
<?xml version="1.0" encoding="UTF-8"?>
<beans:beans xmlns="http://www.springframework.org/schema/mvc"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:beans="http://www.springframework.org/schema/beans"
        xsi:schemaLocation="
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

        <!-- DispatcherServlet Context: defines this servlet's request-processing infrastructure -->
        
        <!-- Enables the Spring MVC @Controller programming model -->
        <annotation-driven />
        <!-- spring mvc對靜態資源的訪問 -->
        <resources location="/image/" mapping="/image/**"/>        
        <resources location="/js/" mapping="/js/**"/>        
        <resources location="/style/" mapping="/style/**"/>        
</beans:beans> 複製代碼

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.