当前位置: 首页>后端>正文

vue3 + vite oss上传(一)

下周就要离开公司了,把手头上的事整理的差不多了,我的小伙伴被隔离要下周来才能交接,趁这个时间写点技术,之前处理了很多的oss、aws上传今天写下来,以后可能会用到,下面先说说oss的简单上传方式,因为分片上传最好100m以上,但这个分片上传呢,我们在开发服、测试服的时候都可以用,而生产环境因为运维那边配置了严格的权限,最后在生产环境用不了,还是用了简单上传,不管是简单上传还是分片上传,百度都有方法,只是参数不对就会影响上传

1、先说client.put简单上传的参数,需要引入oss的sdk

const params = {

????"dir":this.uploadData.dir, //路径

? ? "district":"CHN",

? ? "serviceType":1,

? ? "tenantId":'0'

}

这是传给后端签名的参数

let reg = new RegExp(".aliyuncs.com")

this.ossGetAccessUrlData = {...res.result, region: res.result.host.replace(reg, "")} //host的数据替换

this.client = new OSS({

? ? region: this.ossGetAccessUrlData.region, //桶所在区域 这个必须要,我看到很多文档没有的

? ? secure: true,? //设置secure为true,则使用HTTPS;设置secure为false,则使用HTTP

? ? policy: this.ossGetAccessUrlData.policy,

? ? accessKeyId: this.ossGetAccessUrlData.accessid, //通过阿里云控制台创建的AccessKey ID

? ? accessKeySecret: this.ossGetAccessUrlData.secret, //通过阿里云控制台创建的AccessKey Secret。

? ? bucket: this.ossGetAccessUrlData.bucket, //桶

? ? signature: this.ossGetAccessUrlData.signature //签名字符串

})

然后就可以this.client.put(this.uploadData.dir, this.file),下面是代码贴图

vue3 + vite oss上传(一),第1张

但是这种方式有个缺陷就是暴露了?secret,所以就换了post方式

1、post方式就直接简化了上传方式,就是唯一的缺点是不知道进度多少,但为了保密,运维同事就通过配置加速了上传,还挺快的

跟上面一样获取签名返回的数据ossGetAccessUrlData,下面就是上传了,不需要引入oss的sdk

let multipart_params =formData({

'key': dir, // 文件存储路径

? ? 'policy': ossGetAccessUrlData.policy, // Policy表单域用于验证请求的合法性

? ? 'success_action_status':200, // 文件上传成功服务器返回的状态

? ? 'OSSAccessKeyId': ossGetAccessUrlData.accessid, //accessid

? ? 'signature': ossGetAccessUrlData.signature,

? ? 'file': file

});

//上传域名

const domain ='https://' + ossGetAccessUrlData.bucket +'.' + ossGetAccessUrlData.host;

//请求头配置

const config = {headers: {'Accept':'application/json, text/javascript, */*; q=0.01', 'Content-Type':'multipart/form-data'}}; // 配置请求头

//正式上传

let result =new Promise(async (resolve, reject) => {

//oss用post域名即可

? ? await axios.post(domain, multipart_params, config).then((res) => {

if (res.status ===200) {

resolve(domain +'/' + multipart_params?.get('key'))

}else {

reject(res)

}

})

})

return result;

就这样,分片上传呢用下面的代码,这里就不贴代码了

在我的AIOT项目upgradeManagement/deviceUpgrade/upgradeUpload.vue中,只为记录让自己记得,哈哈哈


https://www.xamrdz.com/backend/3ud1926451.html

相关文章: