如何你的DispatcherServlet拦截 *.do这样的URL,就不存在访问不到静态资源的问题。如果你的DispatcherServlet拦截“/”,拦截了所有的请求,同时对*.js,*.jpg的访问也就被拦截了。

目的:可以正常访问静态文件,不要找不到静态文件报404。

方案一:激活Tomcat的defaultServlet来处理静态文件

<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>  
要配置多个,每种文件配置一个   

要写在DispatcherServlet的前面, 让defaultServlet先拦截,这个就不会进入Spring了,我想性能是最好的吧。

Tomcat, Jetty, JBoss, and GlassFish  默认 Servlet的名字 -- "default"
Google App Engine 默认 Servlet的名字 -- "_ah_default"
Resin 默认 Servlet的名字 -- "resin-file"
WebLogic 默认 Servlet的名字  -- "FileServlet"
WebSphere  默认 Servlet的名字 -- "SimpleFileServlet"

方案二: 在spring3.0.4以后版本提供了mvc:resources 

(项目中使用了:

      String fileName = upload.getOriginalFilename();

      System.out.println("图片名:"+fileName);
      fileName = UUID.randomUUID().toString()+ fileName.substring(fileName.lastIndexOf("."));
      //String path = request.getSession().getServletContext().getRealPath("upload/draft");
      String path="upload/draft/image/";
      String realPath = request.getSession().getServletContext().getRealPath(path);

      String baseUri = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+request.getContextPath()+"/";

      String imagePath = baseUri+path+fileName; //上传的图片路径

<mvc:resources 的使用方法:

<!--对静态资源文件的访问-->
<mvc:resources mapping="/images/**" location="/images/" />

/images /**映射到 ResourceHttpRequestHandler 进行处理,location指定静态资源的位置.可以是web application根目录下、jar包里面,这样可以把静态资源压缩到jar包中。cache-period可以使得静态资源进行web cache

如果出现下面的错误,可能是没有配置 <mvc:annotation-driven /> 的原因。 
报错WARNING: No mapping found for HTTP request with URI [/mvc/user/findUser/lisi/770] in DispatcherServlet with name 'springMVC'

使用 <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.

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

<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,就不存上述问题了。

转自:http://lzy83925.iteye.com/blog/1186609

最新文章

  1. Beta阶段第六次Scrum Meeting
  2. fir.im Weekly - 暖心的 iOS 持续集成,你值得拥有
  3. 在 C# 中执行 msi 安装
  4. Windows远程数据同步工具cwRsync
  5. Linux截屏工具scrot用法详细介绍
  6. SharedPrefernces使用实例讲解
  7. CNN中的BN
  8. Pig与Hive的区别
  9. java基础知识回顾之java Thread类学习(十二)-- 线程中断
  10. 指令式Callback,函数式Promise:对node.js的一声叹息
  11. Android开发UI之去掉title bar
  12. 转 - Web新人(偏前端)应该怎样学习(个人观点,勿喷)
  13. sql 根据时间获取数据
  14. 修炼dp(1)
  15. 【前端】nodejs的ORM框架sequelize的工厂化
  16. maven项目自动创建src/main/resources等四个资源文件夹
  17. 从零基础到拿到网易Java实习offer,谈谈我的学习经验
  18. docker dcm4chee
  19. IdentityServer4 中文文档 -1- (简介)背景
  20. jiedui

热门文章

  1. Redis的安装以及spring整合Redis时出现Could not get a resource from the pool
  2. 中英文字符串截取函数msubstr
  3. Bootstrap历练实例:标签修饰
  4. GTA5(侠盗猎车5)中文版破解版
  5. 119. Pascal&#39;s Triangle II@python
  6. 用宝塔软件在linux上自动安装php环境
  7. Thinkphp5 的常用连式查询
  8. Java-basic-4-数据类型
  9. csapp-15213错误修正18-10-28
  10. Selenium WebDriver-通过断言页面是否存在某些关键字来确定页面按照预期加载