问题:
@RequestMapping(value = "/test",method = RequestMethod.POST)
@ResponseBody
public String test(String name,String id,MultipartFile file){
System.out.println(name);
System.out.println(id);
System.out.println(file.getOriginalFilename());
return "ok";
}
使用poatman进行调用:
发现并没有获取到数据
因为前台默认是传 x-www-form-urlencoded
的数据过来,这时可以获取参数,而传的是form-data
的数据时无法获取,
解决办法
1.导入jar包
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
2.配置,在springmvc.xml中
配置:
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 设定默认编码 -->
<property name="defaultEncoding" value="utf-8"></property>
<!-- 设定文件上传的最大值为5MB,5*1024*1024 -->
<property name="maxUploadSize" value="10485760000"></property>
<!-- 设定文件上传时写入内存的最大值,如果小于这个参数不会生成临时文件,默认为10240 -->
<property name="maxInMemorySize" value="40960"></property>
<!-- 上传文件的临时路径 -->
<property name="uploadTempDir" value="file:WEB-INF/file"></property>
<!-- 延迟文件解析 -->
<property name="resolveLazily" value="true"/>
</bean>
3.或者使用java
配置类来配置
@Bean
public CommonsMultipartResolver multipartResolver(){
CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver();
commonsMultipartResolver.setDefaultEncoding("UTF-8");
commonsMultipartResolver.setMaxUploadSize(10485760000l);
commonsMultipartResolver.setMaxInMemorySize(40960);
return commonsMultipartResolver;
}
重启tomcat
再使用postman进行调用:
可以获取到form-data
的数据了。
springmvc获取静态资源路径
由于早期的 SpringMVC
不能很好地处理静态资源,所以在 web.xml
中配置 DispatcherServlet
的请求映射时,往往采用 \*.do
、\*.xhtml
等方式,这就决定了请求 URL
必须是一个带后缀的 URL
,而无法采用真正 REST
风格的 URL
。
如果将DispatcherServlet
请求映射配置为“/”
,那么Spring MVC
将捕获web容器所有请求,包括静态资源请求,Spring MVC
会将它们当成一个普通请求处理,从而报错。
为什么要使用<mvc:resources/>?
首先,<mvc:resources/>
允许静态资源放置在任何地方,如 WEB-INF
目录下、类路径下等,甚至可以将 JavaScript
等静态文件打包到 JAR
包中,通过 location
属性指定静态资源的位置,由于 location
属性是 Resource
类型,因此可以使用诸如 “classpath:”
等的资源前缀指定资源位置。传统的 Web
容器的静态资源只能放在Web
容器的根路径下,<mvc:resources/>
打破了这个限制。
其次,<mvc:resources/>
可以对静态资源提供优化,例如:通过 cacheSeconds
属性指定静态资源在浏览器端的缓存时间,充分利用浏览器端的缓存,在输出静态资源时,会根据配置设置好响应报文的 Expires
和 Cache-Control
值。在接受到静态资源的获取请求时,会检查请求头的Last_modified
值。如果静态资源没有发生变化,直接返回303
响应状态码,指示客户端使用浏览器缓存的数据。
xml配置
<!--
使用 maven 编译好的结构如下项目结构,可以看出 webapp 下的 html、images、jquery-2.1.1和 WEB-INF 都被编译到了 target 下,唯一变得是 WEB-INF 下多出了 classes 的目录,这个 classes 就是 spring 中俗称的 classpath
location="/" 表示 target 下的 html、images、jquery-2.1.1 这三个文件夹及其子文件,mapping="/resources/**" 表示这三个文件夹的根目录,
也就是说在浏览器输入 http://localhost:8080/项目名/resources/html/goods.html 访问 html 下的 goods.html 文件
-->
<mvc:resources mapping="/resources/**" location="/" />
<!--
映射 target 下的 WEB-INF 及其子文件的根目录为 web,这样在浏览器可以访问 WEB-INF 下的所有文件
例如:http://localhost:8080/项目名/web/web.xml、http://localhost:8080/项目名/web/ftl/freemarker.html
注意:一般情况下,不要配置 WEB-INF
-->
<mvc:resources mapping="/web/**" location="/WEB-INF/" />
<!--
配置 classes 下的文件
访问:http://localhost:8080/项目名/config/conf.json
-->
<mvc:resources mapping="/config/**" location="classpath:config/json/" />
<!--配置d盘下的upload也为静态资源路径-->
<mvc:resources mapping="/upload/**" location="file:///D:/upload/" />
java类配置
@Configuration
//开启mvc注解支持
//<mvc:annotation-driven />
@EnableWebMvc
@ComponentScan("com.zhubayi.ssm.controller")
public class SpringMvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/img/**")
.addResourceLocations("/img/");
registry.addResourceHandler("/css/**")
.addResourceLocations("/css/");
registry.addResourceHandler("/js/**")
.addResourceLocations("/js/");
//配置非项目路径的路径为静态资源路径
registry.addResourceHandler("/upload/**")
.addResourceLocations("file:///D:/upload/");
}
}
项目结构
说明
1、 我们配置的 web 根路径 “/”
下包含 html、jquery-2.1.1、images
和 WEB-INF
,除了 WEB-INF
外,其他三个文件夹都可以访问,而 WEB-INF
不能被访问。因为 SpringMVC
在处理映射的静态资源时,会检查引用路径是否包含 WEB-INF
或者 META-INF
,如果包括,则直接返回 null
。当然我们也可以配置 location="/WEB-INF/"
。
<mvc:resources mapping="/resources/**" location="/" />
<mvc:resources mapping="/web/**" location="/WEB-INF/" />
<mvc:resources mapping="/upload/**" location="file:///D:/upload/" />
2、如果我们设置了 cache-period
属性,即设置静态资源在客户端浏览器中的缓存有效时间,那么当发布了新版本应用时,由于客户端浏览器缓存的缘故,需要使这些静态资源成为“新的资源”,例如给静态资源的路径添加应用发布的版本号