vue上传图片接口file传值为空怎么回事?

发布于 2022-09-06 19:42:28 字数 1269 浏览 27 评论 0

使用file参数请求接口时如何让参数不为空?应该怎么像postman中那样传参?
postman中可以直接使用file上传
图片描述

接口:

API.goods.fileupload({'file':this.fileinfo[0].file}).then((resp) => {

})

Network中可以看到参数为空:
图片描述

this.fileinfo[0]值为:
图片描述


接口地址:

fileupload(data, token) {
    if (localStorage.getItem('login')) {
        var token = localStorage.getItem("access_token")
    }
    return axios.post(API_ROOT + '/v1/feedback/feedback/fileupload-frq?access-token=' + token, qs.stringify(data))
}

请求接口:

let formData = new FormData();
formData.append("file", this.fileinfo[0].file);
API.goods.fileupload(formData).then((resp) => {})

图片描述

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

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

发布评论

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

评论(3

末蓝 2022-09-13 19:42:28

获取到file的dom对象
然后使用FormData构建

嘿咻 2022-09-13 19:42:28
  formData.append("file", file);
  // 错误的示范,千万不要将formData包一层花括号,这会导致上传的值为{file: {}},也就是空值,这是一个陷阱,我想很多人应该遇到过
  axios.post("/upload", { file: formData });
  // 要这样,直接上传formData
  axios.post("/upload", formData);

并且不需要设置Content-Type

╄→承喏 2022-09-13 19:42:28

传文件使用FormData对象
FormData 对象的使用

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文