Vue上传通过“服务端签名后直传”上传文件到阿里云 报错 400 Bad Request

我报错的原因是 formData.append('file', file) 放在签名前面了

解决办法 formData.append('file', file) 一定在最后

/**
 * 上传文件到 oss
 * @param {} Object Sign  签名 
 * @param {*} file 要上传的文件
 */
export const updateFileToOSS = (sing, file) => {
  // console.log(file)
  const formData = new FormData()
  formData.append('key', sing.key)
  formData.append('OSSAccessKeyId', sing.accessid)
  formData.append('policy', sing.policy)
  formData.append('signature', sing.signature)
  formData.append('success_action_status', '201')
  formData.append('file', file) // 一定在最后
  return new Promise((resolve, reject) => {
    axios({
      method: 'POST',
      url: '/oss', // 设置代理了
      data: formData,
      headers:{
        'Authorization': Vue.ls.get(ACCESS_TOKEN), // 请求头携带的token
        'Content-Type': 'multipart/form-data'
      }
    }).then((response) => {
      resolve(response)
    }).catch(error => {
      reject(error)
    })
  })
}

感谢 原文 https://segmentfault.com/a/1190000019481380

转载于:https://www.cnblogs.com/ybixian/p/11369121.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值