Vue使用AWS S3 sdk,通过STS上传文件至OSS/MINIO
vue
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
项目地址:https://gitcode.com/gh_mirrors/vu/vue
免费下载资源
·
一、背景
采用客户端直传方式,直接上传文件到存储器(OSS/MINIO),这里是通过临时认证(STS)来连接存储器
二、vue demo
1.引入aws sdk
import AWS from 'aws-sdk';
2.获取连接存储器参数
let { accessKeyId, accessKeySecret, securityToken, bucketName, dir, endpoint, region, storageType } = this.uploadConfig;
其中,uploadConfig为获取连接存储器参数的接口方法
3.创建s3客户端
AWS.config.update({
accessKeyId: accessKeyId,
secretAccessKey: accessKeySecret,
sessionToken: securityToken,
endpoint,
s3ForcePathStyle: storageType === '1', // 如果使用 MinIO,请设置为true
region // 'cn-north-1' // MinIO 储存区域
});
let s3 = new AWS.S3();
4.上传文件
return new Promise((reslove, reject) => {
s3.upload({
Bucket: bucketName,
Key: dir + fileName,
Body: file
}, (err, data) => {
if (err) {
console.log(err);
// 上传失败
} else if (data) {
// 上传成功,可以与应用服务交互,上报上传成功的文件信息
// console.log(data);
let params = {
fileInfo: {
path: dir + fileName,
size: file.size,
name: fileName,
source: storageType,
contentType: file.type,
url: data.Location
},
dealType: this.dealType
};
// 与应用服务交互接口,自信定义
commonApi.uploadFileCallback(params).then(r => {
if (r.data.code === 0) {
// console.log('回调成功');
}
});
reslove(data.Location);
}
});
});
三、小结
使用aws 通过sts方式直传文件,虽然通用,但是在配置S3客户端时要辨别s3ForcePathStyle参数
GitHub 加速计划 / vu / vue
207.53 K
33.66 K
下载
vuejs/vue: 是一个用于构建用户界面的 JavaScript 框架,具有简洁的语法和丰富的组件库,可以用于开发单页面应用程序和多页面应用程序。
最近提交(Master分支:1 个月前 )
73486cb5
* chore: fix link broken
Signed-off-by: snoppy <michaleli@foxmail.com>
* Update packages/template-compiler/README.md [skip ci]
---------
Signed-off-by: snoppy <michaleli@foxmail.com>
Co-authored-by: Eduardo San Martin Morote <posva@users.noreply.github.com> 3 个月前
e428d891
Updated Browser Compatibility reference. The previous currently returns HTTP 404. 4 个月前
更多推荐
已为社区贡献2条内容
所有评论(0)