最近在弄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先攔截,這個就不會進入Spring了spring
方案二: 在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,就不存上述問題了。