@RequestPart-同时上传文件和json的解决方案

 

 

后台接收代码:

@RequestMapping("jsonDataAndUploadFile")
@ResponseBody
public String jsonDataAndUploadFile(@RequestPart("uploadFile") List<MultipartFile> uploadFiles,
                                    @RequestPart("jsonData") Person person) {
    StringBuilder sb = new StringBuilder();
    uploadFiles.forEach(u -> sb.append(u.getOriginalFilename()).append(";;;"));
    return person.toString() + ":::" + sb.toString();
}

  

前台请求:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
POST /demo/jsonDataAndUploadFile HTTP/1.1
Host: localhost:2323
Content-Type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW
 
----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="jsonData"
Content-Type: applicatoin/json
 
{"name":"jack", "age":25}
----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="uploadFile"; filename="/C:/Users/thunisoft/Desktop/20191226105639.png"
Content-Type: image/png
 
(data)
----WebKitFormBoundary7MA4YWxkTrZu0gW

 

 

注意事项:

1.上述请求中使用POST方式,并且请求类型为 Content-Type: multipart/form-data; 同时上传两种参数一种为字符串类型参数,另一种为文件类型参数。

2.通常SpringMVC只能将json字符串解析为普通字符串变量,无法直接序列化为对象对象。

也就是只能通过@RequestParam("josnData") String jsonData 和@RequestPart("uploadFile") MultiPartFile uploadFile 两个注解分别接受参数,此时使用@RequestParam("josnData")注解接受的类型只能为String。

 

具体使用:

可以使用@RequestPart注解接受JSON数据,此时可以将接收的json字符串直接序列化为实例对象。如上后台代码。

注意:此时json字符串一定要声明类型 Content-Type: application/json,否则使用@RequestPart注解无法反序列化(源码参考:最下面)

参考该代码片段:

----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="jsonData"
Content-Type: applicatoin/json

{"name":"jack", "age":25}

----WebKitFormBoundary7MA4YWxkTrZu0gW

 

源码解析:

1
2
3
4
5
6
7
8
org.springframework.web.servlet.mvc.method.annotation.RequestPartMethodArgumentResolver#resolveArgument
    HttpInputMessage inputMessage = new RequestPartServletServerHttpRequest(servletRequest, name);
    上面两行会根据参数名称以及请求实例化请求流。
     
        org.springframework.web.multipart.support.RequestPartServletServerHttpRequest#RequestPartServletServerHttpRequest
            HttpHeaders headers = this.multipartRequest.getMultipartHeaders(this.partName);
            在RequestPartServletServerHttpRequest初始化时候,会获取请求参数的请求头信息,如果头为空则会报异常操作
            如果存在则会正常解析内容。

  

 

posted @   GordonDicaprio  阅读(19558)  评论(1编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
历史上的今天:
2018-03-12 Spring Cloud Eureka 注册中心 服务消费者 服务提供者之间的关系以及高可用之间的联系
2018-03-12 Spring Cloud Eureka 集群搭建 - 以及发现一个 “直觉BUG”
2018-03-12 IDEA 中 同一个微服务 按照多个端口启动
2018-03-12 Eureka 高可用
点击右上角即可分享
微信分享提示