spring-mvc裏的 及靜態資源訪問

轉載地址 :https://www.cnblogs.com/linnuo/p/7699401.htmlcss

在進行Spring MVC的配置時,一般咱們會配置一個dispatcher servlet用於處理對應的URL。配置以下:html

複製代碼
<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>
複製代碼

 

只攔截.do請求配置以下:web

<servlet-mapping>  
    <servlet-name>springMVC</servlet-name>  
    <url-pattern>*.do</url-pattern>  
</servlet-mapping>

 

 

這表示名字爲 SpringMVC 的servlet會處理一切的url對應的請求,那麼咱們怎麼讓servlet來處理項目中的靜態資源呢?這裏有兩種方法。spring

  1. 另外使用一個servlet來處理靜態資源。若咱們的資源放置在webapps文件夾下的resources文件夾中,那麼咱們能夠用名字爲default的servlet來處理靜態資源。所以咱們還須要在上述配置的基礎上加上如下配置:spring-mvc

<servlet-mapping>  
<servlet-name>default</servlet-name>  
<url-pattern>resources/*</url-pattern>  
</servlet-mapping>

這表示default的servlet會處理url中爲resources/*的對應的請求。這樣,當你把你的image,css已經其餘文件放在resources文件中時,spring就能夠找到它啦。mvc

 

2. 採用spring自帶<mvc:resources>方法。首先找到你定義的那個servlet的xml文件,如本例子中,servlet的名字叫mvc-dispatcher,所以須要找到mvc-dispatcher-servlet.xml文件,並在該文件中插入如下配置:app

<mvc:annotation-driven/>  
<mvc:resources mapping="/resources/**/" location="/resources/"/>

如此就沒必要另外添加一個mvc來處理靜態資源。而mvc知道靜態資源所處的位置爲resources文件夾。
兩種方法均可以將spring mvc配置處理靜態資源。webapp

 

在SpringMVC3.0以後推薦使用一: url

<mvc:annotation-driven />
 <mvc:resources location="/img/" mapping="/img/**"/>   
 <mvc:resources location="/js/" mapping="/js/**"/>    
 <mvc:resources location="/css/" mapping="/css/**"/>

說明:spa

location元素表示webapp目錄下的static包下的全部文件;

mapping元素表示以/static開頭的全部請求路徑,如/static/a 或者/static/a/b;

該配置的做用是:DispatcherServlet不會攔截以/static開頭的全部請求路徑,並看成靜態資源

交由Servlet處理。

 

 

也能夠使用二:

web.xml裏添加以下的配置

複製代碼
<servlet-mapping>  
     <servlet-name>default</servlet-name>  
     <url-pattern>*.css</url-pattern>  
</servlet-mapping>  
  
<servlet-mapping>  
    <servlet-name>default</servlet-name>  
    <url-pattern>*.gif</url-pattern>  
  
</servlet-mapping>  
     
<servlet-mapping>  
     <servlet-name>default</servlet-name>  
     <url-pattern>*.jpg</url-pattern>  
</servlet-mapping>  
     
<servlet-mapping>  
     <servlet-name>default</servlet-name>  
     <url-pattern>*.js</url-pattern>  
</servlet-mapping>
複製代碼

 相關:https://www.cnblogs.com/caogen1991/p/7921748.html

相關文章
相關標籤/搜索