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()
}
基于Vue3使用阿里云OSS上传图片,你需要先确保已经注册了阿里云账号,并且创建了OSS服务,获取了相应的AccessKey ID和AccessKey Secret以及设置好了存储空间(Bucket)。 以下是使用Vue3结合阿里云OSS进行图片上传的基本步骤: 1. 安装 OSS SDK for JavaScript: 通过npm或yarn安装SDK,可以在项目中的终端运行以下命令: ``` npm install oss-sdk --save 或者 yarn add oss-sdk ``` 2. 创建OSS客户端实例: 在Vue3项目中,你可以在相应的组件中创建一个OSS客户端实例,通常是在methods或者setup函数中,使用你的AccessKey信息: ```javascript import OSS from &#39;oss-sdk&#39;; import { ref } from &#39;vue&#39;; const bucket = &#39;your-bucket-name&#39;; // 替换为你的Bucket名称 const accessKeyId = &#39;your-access-key-id&#39;; // 替换为你的AccessKey ID const accessKeySecret = &#39;your-access-key-secret&#39;; // 替换为你的AccessKey Secret const client = new OSS({ region: &#39;oss-region&#39;, // 替换为你的OSS区域 accessKeyId: accessKeyId, accessKeySecret: accessKeySecret, bucket: bucket }); ``` 3. 上传图片: 你可以创建一个方法来处理文件的上传。首先,获取要上传的文件,然后使用OSS实例的`put`方法上传图片。 ```javascript const uploadImage = async (file) => { const res = await client.put(&#39;path/to/upload&#39;, file); // &#39;path/to/upload&#39;是目标路径和文件名 console.log(&#39;upload success:&#39;, res); }; ``` 4. 使用组件上传图片: 你可以在Vue模板中添加一个文件输入元素,并在用户选择文件后调用`uploadImage`方法上传图片: ```html <input type="file" @change="handleFileUpload" /> ``` 在相应的方法中,你可以处理文件选择事件并获取文件对象: ```javascript const handleFileUpload = async (event) => { const files = event.target.files; if (files.length > 0) { const file = files[0]; await uploadImage(file); } }; ``` 确保在使用这些代码前,你已经正确配置了安全凭证和OSS服务,并且你的网络请求符合阿里云的安全要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值