首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Current request is not a multipart request 状态码:511 异常

Current request is not a multipart request 状态码:511 异常

作者头像
用户11865655
发布2025-10-13 16:11:27
发布2025-10-13 16:11:27
15300
代码可运行
举报
文章被收录于专栏:CSDN专栏CSDN专栏
运行总次数:0
代码可运行

1.文件上传的流程:

但要在form表单中上传文件时,我们使用 SpringBoot 可以减少我们的配置流程。而在这里配置只需要配置成这样就好

代码语言:javascript
代码运行次数:0
运行
复制
public String upload(
        @RequestPart("wallpaperInputFile") MultipartFile wallpaperInputFile,
        @RequestPart("photos") MultipartFile[] photos) throws IOException {}

我们直接使用参数接收,在视图部分用file属性的input标签发送请求即可。 但是,有时候我们会遇到511报错?亦可以说是: Current request is not a multipart request 下图这个报错:

这是为什么?

2.异常的根源:

在发送带文件的请求时,请求头的信息应该是multipart/form-data。 出现这样的报错,多半是前端没有默认请求头。 而发掘请求的相关参数,也确实可以看到请求头是不符合文件上传要求的。

3.异常解决:

既然了解了bug从何而来,那么解决思路就清晰了,说到底不就是请求头不规范嘛。

3.1 视图部分:

在视图的form表单标签上,加上限定请求头的信息。

也就是:enctype=”multipart/form-data” 该属性就可以限定发起请求时的请求头

但如果这样还不能解决Bug…那接下来处理控制器部分

3.2 控制器部分:

  • 如果表单上限定了请求头信息,那控制器上可以无需添加!
  • 但如果表单上已经限定了请求头信息,还没有效果!那追加上控制器部分

实际上,@xxxMapping 注解是有规定请求头的参数的,我们只需设定这个参数即可。

Consumes 属性,也可以用来限定请求头信息,后面的常量就是请求头的信息。

点进常量一看就可以发现SpringBoot已经给我们封装好了。直接使用即可

4. 解决

当视图和控制器部分都追加了请求头的限定信息,那自然bug就完成了。

如图可见,请求状态码正常,请求头信息已经更改。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-10-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.文件上传的流程:
  • 2.异常的根源:
  • 3.异常解决:
    • 3.1 视图部分:
    • 3.2 控制器部分:
  • 4. 解决
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档