Vue使用AWS S3 sdk,通过STS上传文件至OSS/MINIO

一、背景

采用客户端直传方式,直接上传文件到存储器(OSS/MINIO),这里是通过临时认证(STS)来连接存储器

二、vue demo

1.引入aws sdk

javascript 复制代码
import AWS from 'aws-sdk';

2.获取连接存储器参数

javascript 复制代码
let { accessKeyId, accessKeySecret, securityToken, bucketName, dir, endpoint, region, storageType } = this.uploadConfig;

其中,uploadConfig为获取连接存储器参数的接口方法

3.创建s3客户端

javascript 复制代码
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.上传文件

javascript 复制代码
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参数

相关推荐
优弧2 分钟前
Claude 终于对普通人下手了!Cowork 发布,你的最强 AI 打工搭子来了!
前端·后端
Zoey的笔记本25 分钟前
敏捷与稳定并行:Scrum看板+BPM工具选型指南
大数据·前端·数据库·python·低代码
文心快码BaiduComate27 分钟前
0代码手写!体验百度Comate的“魔法”:我造了个会理解情绪的中介层
前端·程序员·前端框架
zhengxianyi51533 分钟前
ruoyi-vue-pro优化——让菜单支持多个参数,一键直达【经营分析】、【生产报表】、【销售报表】
vue.js·前后端分离·数据大屏·ruoyi-vue-pro优化
38242782734 分钟前
表单提交验证:onsubmit与return详解
前端·javascript·html
前端小蜗36 分钟前
普通前端程序员的 2025:没什么大胜利,但也没被生活击倒
前端
bug总结1 小时前
身份证号脱敏的正确实现
前端·javascript·vue.js
林太白1 小时前
Vite8 Beta来了,Rolldown携手Oxc
前端·javascript·后端
xkxnq1 小时前
第二阶段:Vue 组件化开发(第 19天)
前端·javascript·vue.js
技术净胜2 小时前
Python 操作 Cookie 完全指南,爬虫与 Web 开发实战
前端·爬虫·python