文件上传失败原因分析与解决

图片文件上传失败

问题描述:在前端开发时,需要通过表单元素上传图片或其他文本,但是上传不成功,后端接口也没问题

html 复制代码
```html
<!--onChange用来绑定数据   handleUpload用来提交数据-->
      <form onSubmit={handleUpload}>
        <input type="file" onChange={handleFileChange} />
        <button type="submit" style={{ width: "100px" }} className="btn">
          图片上传
        </button>
      </form>
```
javascript 复制代码
//注意封装axios时记得修改axios的请求头对应的content-type:
//axios.default.......
const handleUpload = (event) => {
    event.preventDefault();
    // 记得使用FormData
    const file = new FormData();
    file.append("file", selectedFile);
    axios({
      method: "post",
      url: "后端接口",
      data: file,
    }).then((res) => {
      if (res.data.status == 200) {
        message.success("上传成功");
      }
    });
  };

报错内容 :Current request is not a multipart request

原因分析 :Http请求中的头部信息(header),content-type内容不对应,修改为multipart/form-data即可

扩展

json 复制代码
//Content-Type 是 什么?
HTTP 协议中的一个请求头或响应头字段,用于指示发送或接收的实体的媒体类型,告诉服务器或客户端如何解析和处理请求或响应的主体部分。
//常用的content-type有哪些?
application/json:表示json 数据  
multipart/form-data: 生成边界来分割字段,支持文件上传的格式。
application/x-www-form-urlencoded :HTTP 会将请求参数用 key1=val1&key2=val2 的方式拼接,并放到请求实体里面,不支持文件,一般用于表单提交。  
text/plain:纯文本格式
相关推荐
CHU72903522 分钟前
一番赏盲盒抽卡机小程序:解锁惊喜体验与社交乐趣的多元功能设计
前端·小程序·php
RFCEO23 分钟前
前端编程 课程十二、:CSS 基础应用 Flex 布局
前端·css·flex 布局·css3原生自带的布局模块·flexible box·弹性盒布局·垂直居中困难
天若有情6731 小时前
XiangJsonCraft v1.2.0重大更新解读:本地配置优先+全量容错,JSON解耦开发体验再升级
前端·javascript·npm·json·xiangjsoncraft
2501_944525541 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 预算详情页面
android·开发语言·前端·javascript·flutter·ecmascript
打小就很皮...1 小时前
《在 React/Vue 项目中引入 Supademo 实现交互式新手指引》
前端·supademo·新手指引
C澒1 小时前
系统初始化成功率下降排查实践
前端·安全·运维开发
摘星编程2 小时前
React Native + OpenHarmony:自定义useFormik表单处理
javascript·react native·react.js
C澒2 小时前
面单打印服务的监控检查事项
前端·后端·安全·运维开发·交通物流
pas1362 小时前
39-mini-vue 实现解析 text 功能
前端·javascript·vue.js
qq_532453532 小时前
使用 GaussianSplats3D 在 Vue 3 中构建交互式 3D 高斯点云查看器
前端·vue.js·3d