一、背景
采用客户端直传方式,直接上传文件到存储器(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,请设置为trueregion // '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参数