ant design vue 手动上传(上传成功)但后台无法获取文件

发布于 2022-09-13 01:07:12 字数 1309 浏览 16 评论 0

跟后台同事调试了半天,前台这块能打出一个日期一个上传文件。

 console.log(formData.get('file'))       //能打印出上传文件
 console.log(formData.get('acctMonth'))  //能打印出日期

上传是反馈200成功,但后台就是显示找不到上传文件。

handleUpload() {
  if (this.acctMonth == "") {
    this.$message.error("请选择账期!")
    return false;
  }
  if (this.fileList == "") {
    this.$message.error("请选择上传文件!")
    return false;
  }
  const { fileList } = this;
  const formData = new FormData();
  let token = Vue.ls.get(ACCESS_TOKEN);

  fileList.forEach((file) => {
    formData.append("file", file);
  });
  formData.append("acctMonth", this.acctMonth);
  this.uploading = true;
  
  console.log(formData.get('file'))       //能打印出上传文件
  console.log(formData.get('acctMonth'))  //能打印出日期

  reqwest({
    url: apiUrl.upload,                  //后台上传接口
    method: 'post',
    data: formData,
    headers: {                           //框架需要支持token才能上传
      "content-type": "multipart/form-data",
      "X-Access-Token": token
    },
    success: () => {
      console.log(formData.getall())
      this.fileList = [];
      this.acctMonth = '';
      this.uploading = false;
      this.$message.success('文件上传成功.');
    },
    error: () => {
      this.uploading = false;
      this.$message.error('文件上传失败.');
    },
  });
},

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

半世蒼涼 2022-09-20 01:07:12

两个可能。

  1. 前端发的并不是 form-data
  2. 发送的时候把文件丢了。或者名字(文件名)不对。有的框架会要求文件名。

可以考虑把 network 搞出来看看


百度都怀疑我搜索错了
image.png


看上去是你写的不对。

reqwest({
      url: '/safe/face/faceCompareForSavePic',   //这块是你项目的接口
      method: 'post',
      processData: false,
      data: formData,
      success: () => {
        this.setState({
          fileList,
          uploading: false,
        });
        message.success('upload successfully.');
      },
      error: () => {
        this.setState({
          uploading: false,
        });
        message.error('upload failed.');
      },
    });
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文