SpringMVC 攔截器不攔截靜態資源的三種處理方式

SpringMVC 攔截器不攔截靜態資源的三種處理方式css

SpringMVC提供<mvc:resources>來設置靜態資源,可是增長該設置若是採用通配符的方式增長攔截器的話仍然會被攔截器攔截,可採用以下方案進行解決:html

方案1、攔截器中增長針對靜態資源不進行過濾(涉及spring-mvc.xml)

<mvc:resources location="/" mapping="/**/*.js"/>  
<mvc:resources location="/" mapping="/**/*.css"/>  
<mvc:resources location="/assets/" mapping="/assets/**/*"/>  
<mvc:resources location="/images/" mapping="/images/*" cache-period="360000"/>

<mvc:interceptors>
    <mvc:interceptor>
        <mvc:mapping path="/**/*"/>
        <mvc:exclude-mapping path="/**/fonts/*"/>
        <mvc:exclude-mapping path="/**/*.css"/>
        <mvc:exclude-mapping path="/**/*.js"/>
        <mvc:exclude-mapping path="/**/*.png"/>
        <mvc:exclude-mapping path="/**/*.gif"/>
        <mvc:exclude-mapping path="/**/*.jpg"/>
        <mvc:exclude-mapping path="/**/*.jpeg"/>
        <mvc:exclude-mapping path="/**/*login*"/>
        <mvc:exclude-mapping path="/**/*Login*"/>
        <bean class="com.imddy.testweb.interceptor.VisitInterceptor"></bean>
    </mvc:interceptor>
</mvc:interceptors>

 

方案2、使用默認的靜態資源處理Servlet處理靜態資源(涉及spring-mvc.xml, web.xml)

在spring-mvc.xml中啓用默認Servletweb

<mvc:default-servlet-handler/>

在web.xml中增長對靜態資源的處理spring

<servlet-mapping>    
    <servlet-name>default</servlet-name>    
    <url-pattern>*.js</url-pattern>    
    <url-pattern>*.css</url-pattern>    
    <url-pattern>/assets/*"</url-pattern>    
    <url-pattern>/images/*</url-pattern>    
</servlet-mapping>

可是當前的設置必須在Spring的Dispatcher的前面spring-mvc

 

方案3、修改Spring的全局攔截設置爲*.do的攔截(涉及web.xml)

<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>
    <async-supported>true</async-supported>
</servlet>
<servlet-mapping>
    <servlet-name>SpringMVC</servlet-name>
    <url-pattern>*.do</url-pattern>
</servlet-mapping>

這樣設置,Spring就會只針對以'.do'結尾的請求進行處理,再也不維護靜態資源
 mvc

針對這三種方案的優劣分析:app

第一種方案配置比較臃腫,多個攔截器時增長文件行數,不推薦使用;第二種方案使用默認的Servlet進行資源文件的訪問,Spring攔截全部請求,而後再將資源文件交由默認的Sevlet進行處理,性能上少有損耗;第三種方案Spring只是處理以'.do'結尾的訪問,性能上更加高效,可是再訪問路徑上必須都以'.do'結尾,URL不太文雅;綜上所述,推薦使用第二和第三中方案。jsp

 

springmvc的url-pattern配置的三種也模式

1: [ / ] 表示:
會匹配到/login這樣的路徑型url,不會匹配到模式爲*.jsp這樣的後綴型url。(不會匹配到*.jsp,即:*.jsp不會進入spring的 DispatcherServlet類)。async

2: [ /* ] 表示:
會匹配全部url:路徑型的和後綴型的url(包括/login,*.jsp,*.js和*.html等)。(會匹配*.jsp,會出現返回jsp視圖時再次進入spring的DispatcherServlet 類,致使找不到對應的controller因此報404錯)。性能

3: [ *.do ] 表示: 只匹配後綴名爲.do的請求。

相關文章
相關標籤/搜索