Vue3使用阿里云OSS直传

采用Browser.js简单上传,官网:

如何使用Browser.js SDK简单上传文件_对象存储 OSS-阿里云帮助中心

安装:

npm install ali-oss

首先获取临时访问凭证包括临时访问密钥(AccessKey ID和AccessKey Secret)和安全令牌(SecurityToken) 

获取临时密钥加安全令牌,通过从后端获取,令牌存储前端非常不安全,可以通过抓包工具进行抓取。

const client = ref(null) //oss授权信息


// 获取密钥信息
async function getosssa() {
    // 从后端获取密钥
    let data = await useOssApi().getoss({})
    miyao = data.data
    client.value = new OSS({
        // yourRegion填写Bucket所在地域。以华东1(杭州)为例,yourRegion填写为oss-cn-hangzhou。
        region: "oss-cn-hangzhou",
        // 从STS服务获取的临时访问密钥(AccessKey ID和AccessKey Secret)。
        accessKeyId: miyao.accessKeyId,
        accessKeySecret: miyao.accessKeySecret,
        // 从STS服务获取的安全令牌(SecurityToken)。
        stsToken: miyao.securityToken,
        // 填写Bucket名称。
        bucket: miyao.bucketName,
    });
}

 使用elemet-plus上传组件,自定义上传

  

<el-upload accept="excel" class="upload-demo" ref="uploads" 
                            :http-request="uploadFile" :file-list="fileList" :on-message="message"
                            :auto-upload="false">
                            <template #trigger>
                                <el-button type="success">选取文件</el-button>
                            </template>
                            <el-button style="margin-left: 10px;" type="success" @click="submitUpload">开始上传</el-button>
                            <el-button style="margin-left: 10px;margin-top: 15px;" type="primary"
                            <template #tip>
                                <!-- <div class="el-upload__tip">只能上传 jpg/png 文件,且不超过 500kb</div> -->
                            </template>
                        </el-upload>
// 唯一uuid
const getFileNameUUID = () => {
    function rx() {
        return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1)
    }
    return `${+new Date()}${rx()}${rx()}`
}

自定义上传方法:

// 上传文件
const uploadFile = async (file) => {
    if (file) {
        const options = {
            meta: { temp: "demo" },
            mime: "json",
            headers: { "Content-Type": "text/plain" },
        }
        try { 
            // getFileNameUUID() 生成唯一值  file.file获取文件流
            const result = await client.value.put(`${getFileNameUUID()}.xlsx`, file.file, options)
            // result.url 获取上传后的url地址,传给后端,后端做数据处理
            oosurl.value = result.url
        } catch (e) {
        }
    } else {
        ElMessage.warning({
            message: 'No file selected',
            type: 'warning'
        });
    }
}

上传组件绑定ref,手动控制上传

const uploads = ref() //上传


// 开始上传
function submitUpload() {
    uploads.value.submit()
}

相关推荐

  1. Vue3使用阿里OSS

    2023-12-05 18:08:01       65 阅读
  2. 如何使用阿里OSS进行前端

    2023-12-05 18:08:01       44 阅读
  3. 3.上图片(阿里空间,oss验证)

    2023-12-05 18:08:01       25 阅读
  4. 如何使用断点续方式上大文件到阿里 OSS

    2023-12-05 18:08:01       20 阅读
  5. 使用Go-Gin框架实现 OSS 前端功能

    2023-12-05 18:08:01       53 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-05 18:08:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-05 18:08:01       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-05 18:08:01       82 阅读
  4. Python语言-面向对象

    2023-12-05 18:08:01       91 阅读

热门阅读

  1. 【无标题】

    2023-12-05 18:08:01       72 阅读
  2. Linux: FS: inotify

    2023-12-05 18:08:01       48 阅读
  3. pandas.get_dummies函数:把离散信息转换成onehot矩阵

    2023-12-05 18:08:01       54 阅读
  4. 矩阵的初等变换

    2023-12-05 18:08:01       51 阅读
  5. 时间戳,标准时间之间的转化

    2023-12-05 18:08:01       62 阅读
  6. PTA 7-223 sdut-C语言实验-求阶乘(循环结构)

    2023-12-05 18:08:01       56 阅读