axios上传文件以及遇到的问题

axios上传文件以及遇到的问题axios上传文件以及遇到的问题1,这里上传文件使用的是elementUI的上传,也用原生的input上传写了,但是没有时间做多文件上传,下面会把代码贴出。2,这里上传文件我是先获取OSS权限和上传路径,然后再上传。但是权限获取成功后,上传到阿里云服务器时,OPTION请求报403。原因是项目中axios设置了拦截器,添加了config配置,但是在axios发送OPTION测试接口是否有权限访…

大家好,又见面了,我是你们的朋友全栈君。

axios上传文件以及遇到的问题

1,这里上传文件使用的是elementUI的上传,也用原生的input上传写了,但是没有时间做多文件上传,下面会把代码贴出。
2,这里上传文件我是先获取OSS权限和上传路径,然后再上传。但是权限获取成功后,上传到阿里云服务器时,OPTION请求报403。原因是项目中axios设置了拦截器,添加了config配置,但是在axios发送OPTION测试接口是否有权限访问的时候,config的配置必须的干净的,所以这里我的处理方式的单独create一个axios请求。

let instance = axios.create();
instance.post(obj.host, formData).then(res => { 
   
	//oss是请求的文件上传路径接口返回的,formData是上传的文件
    if (res) { 
   
      //拼接上传后的文件路径,
      const fileUrl = obj.host + '/' + obj.imageDir + "/" + imageName + '/' + file.name;
      //将拼接成功的路径保存
      let newUpLoadArr = this.upLoadArray;
      newUpLoadArr.push(fileUrl);
      this.upLoadArray = newUpLoadArr;
    }
})

最后是完整的axios上传文件的代码,时间过于仓促就没有封装组件。

<el-upload
      class="upload-demo"
      multiple
      ref="upload"
      action="https://jsonplaceholder.typicode.com/posts/"
      :on-remove="handleRemove"
      :file-list="fileList"
      :auto-upload="false"
      :on-change="handleChange"
      :http-request="httpRequest"
>
     <el-button size="small" type="primary">点击上传</el-button>
</el-upload>
//原生input输入框文件上传
//<input type="file" @change="handleChange">

//文件列表移除文件时的钩子
handleRemove(file) { 
   
  this.upLoadArray = this.upLoadArray.filter(item => !item.includes(file.name));
},
//文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
handleChange(file, fileList){ 
   
 //上传文件大小限制,Math.pow(2,20)就是1024*1024,需要显示多少兆就把10改成多少兆
 if (file.size > (10 * Math.pow(2, 20))) { 
   
   this.fileList = [];
   this.$message({ 
   
     type: 'warning',
     message: '文件大小超过10M,请重新选择文件!'
   });
   return;
 }
 this.fileList = fileList;
 this.getOSS(file)
},
//覆盖请求
httpRequest(){ 
   },
//获取OSS权限
getOSS(file){ 
   
  get('/oss').then(res => { 
   
    if (res) { 
   
      this.uploadToOss(res, file);
    }
  })
},
//上传服务器
uploadToOss (obj, file) { 
   
  let imageHash = "" + Math.random()
  let imageName = imageHash.substring(2, imageHash.length)
  let formData = new FormData();
  formData.append('key', obj.imageDir + '/' + imageName + '/' + file.name);
  formData.append('policy', obj.policy);
  formData.append('OSSAccessKeyId', obj.accessId);
  formData.append('success_action_status', 200);
  formData.append('signature', obj.signature);
  formData.append("file", file);
  let instance = axios.create();
  instance.post(obj.host, formData).then(res => { 
   
    if (res) { 
   
      const fileUrl = obj.host + '/' + obj.imageDir + "/" + imageName + '/' + file.name;
      let newUpLoadArr = this.upLoadArray;
      newUpLoadArr.push(fileUrl);
      this.upLoadArray = newUpLoadArr;
    }
  }).catch(err => { 
   
    console.log(err)
  });
}

最后附上成品,至于上传成功后的样式,可根据上传成功拼接的文件路径自行设计和调整。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149820.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月17日 下午12:00
下一篇 2022年6月17日 下午12:00


相关推荐

  • 正则表达式常见用例

    正则表达式常见用例

    2022年3月12日
    53
  • WebForms UnobtrusiveValidationMode 需要“jquery”ScriptResourceMapping。「建议收藏」

    WebForms UnobtrusiveValidationMode 需要“jquery”ScriptResourceMapping。「建议收藏」WebForms UnobtrusiveValidationMode 需要“jquery”ScriptResourceMapping。

    2022年4月24日
    68
  • linux系列之常用运维命令整理笔录

    本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新free-m其中:m表示兆,也可以用g,注意都要小写Men:表示物理内存统计total:表示物理内存总数(total=used+free)use…

    2022年4月7日
    42
  • MySQL入门:如何创建数据库?

    MySQL入门:如何创建数据库?本文详细概述了如何使用不同的方法和工具 包括用于 MySQL 的命令行 工作台和 dbForgeStudi 在 MySQL 中创建数据库 MySQL 是基于 SQL 的关系数据库管理系统 它是由 OracleCorpor 开发 分发和支持的 MySQL 是免费的开源软件 由于其可靠性 兼容性 成本效益和全面的支持 它正越来越受到欢迎 MySQL 有一个分支 MariaDB 由 MySQL 的原始开发人员制造 MariaDB 具有相同的数据库结构和索引 因此可以代替 MySQL MySQL 和 MariaDB 都支持

    2026年3月18日
    2
  • python 定义全局变量

    python 定义全局变量python 定义全局变量全局变量可以在代码任意位置创建 能够被所有对象和函数引用 有利于变量的共享 全局变量的定义 global 变量名声明后引用 OLD URL http oldboyedu com defbb globalOLD URLOLD URL OLD URL m if name main bb printOLD URL 输出 http oldboy

    2026年3月26日
    1
  • js实现的A星算法[通俗易懂]

    js实现的A星算法[通俗易懂]一、前言最近在写js的slg游戏,需要用到a星算法。之前用python写过https://blog.csdn.net/qq_39687901/article/details/80753433,现在再用js写一遍。二、源码//二维数组functionArray2D(w,h,num){vardata=[];vardefault_num=num|…

    2026年4月15日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号