SpringMVC+Shiro不攔截靜態資源配置

最近在弄SpringMVC與Shiro整合,發現若是將DispatcherServlet攔截 *.do這樣的URL,就不存在訪問不到靜態資源的問題。若是DispatcherServlet改成攔截「/」,攔截了全部的請求,同時對*.js,*.jpg的訪問也就被攔截了。css

解決方法:
 方案一:激活Tomcat的defaultServlet來處理靜態文件web

<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>
<servlet-mapping>
    <servlet-name>default</servlet-name>
    <url-pattern>*.css</url-pattern>
</servlet-mapping> 
.......

tip:要寫在DispatcherServlet的前面, 讓defaultServlet先攔截,這個就不會進入Springspring

方案二: 在spring3.0.4之後版本提供了mvc:resources mvc

<mvc:resources 的使用方法:
<!--對靜態資源文件的訪問-->
<mvc:resources mapping="/images/**" location="/images/" />

/images/** 映射到 ResourceHttpRequestHandler 進行處理,app

location指定靜態資源的位置.能夠是web application根目錄下、jar包裏面,這樣能夠把靜態資源壓縮到jar包中。cache-period可使得靜態資源進行web cache  性能

報錯WARNING: No mapping found for HTTP request with URI [/mvc/user/findUser/lisi/770] in DispatcherServlet with name 'springMVC'測試

多是沒有配置以下代碼url

 

 <mvc:annotation-driven />

 

 

使用 <mvc:resources/> 元素,把 mapping 的 URI 註冊到 SimpleUrlHandlerMapping的urlMap 中,
key 爲 mapping 的 URI pattern值,而 value爲 ResourceHttpRequestHandler,
這樣就巧妙的把對靜態資源的訪問由 HandlerMapping 轉到 ResourceHttpRequestHandler 處理並返回,因此就支持 classpath 目錄, jar 包內靜態資源的訪問.
另外須要注意的一點是,不要對 SimpleUrlHandlerMapping 設置 defaultHandler. 由於對 static uri 的 defaultHandler 就是ResourceHttpRequestHandler,
不然沒法處理static resources request.spa

方案三 ,使用<mvc:default-servlet-handler/>code

 

<mvc:default-servlet-handler/>

 

 把 "/**" url,註冊到 SimpleUrlHandlerMapping 的 urlMap 中,把對靜態資源的訪問由 HandlerMapping 轉到 org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler 處理並返回.

DefaultServletHttpRequestHandler 使用就是各個 Servlet 容器本身的默認 Servlet.

補充說明:多個HandlerMapping的執行順序問題:

DefaultAnnotationHandlerMapping 的 order 屬性值是:0

<mvc:resources/ >自動註冊的 SimpleUrlHandlerMapping 的 order 屬性值是: 2147483646

<mvc:default-servlet-handler/>自動註冊的 SimpleUrlHandlerMapping 的 order 屬性值是:2147483647

spring 會 先執行 order 值比較小的。當訪問一個 a.jpg 圖片文件時,先經過 DefaultAnnotationHandlerMapping 來找處理器,必定是找不到的,咱們沒有叫 a.jpg 的 Action。再按 order 值升序找,因爲最後一個 SimpleUrlHandlerMapping 是匹配 "/**" 的,因此必定會匹配上,再響應圖片。

訪問一個圖片,還要走層層匹配。真不知性能如何?改天作一下壓力測試,與Apache比一比。

最後再說明一下,如何你的 DispatcherServlet 攔截 *.do 這樣的 URL,就不存上述問題了。

相關文章
相關標籤/搜索