项目性能优化之七牛云对象存储

前端:

        安装第三方包:

pnpm i qiniu-js

        前端代码:

<div>
    <input type="file" ref="fileInput" />
    <button @click="uploadFun">上传文件</button>
</div>
<script setup lang="ts">
import * as qiniu from 'qiniu-js'
import { ref } from 'vue'
    
const fileInput = ref<HTMLInputElement | null>(null)

async function uploadFun() {
    const file = fileInput.value.files[0]
    console.log(file, 'files')

    const result = await getUploadToken()
    console.log(result, 'result')
    const token = result.data
    const key = file.name
    const putExtra = {
        fname: key,
    }
    const config = {
        useCdnDomain: true,
        region: qiniu.region.z1,
    }

    const observable = qiniu.upload(file, key, token, putExtra, config)

    const observer = {
        next(res) {
            console.log(res)
        },
        error(err) {
            console.log(err, 'err')
        },
        complete(res) {
            console.log(res, 'res')
        },
    }
    observable.subscribe(observer)
    // 在项目中,根据不同组件(执行环境)需要不同的返回值。
    // 在react + antd-mobile + ImageUploader 图片上传中,需要返回一个Promise对象,并且该对象中需要拥有url属性。
    // return Promise.resolve({url:'XXXXXX'})
}
</script>

        注意事项:

        在项目中,根据不同组件(执行环境)需要不同的返回值。

后端:

        安装第三方包:

pnpm i qiniu

        config/index.js

module.exports = {
    Ak:'',
    Sk:'',
}

        routes/upload.js

var express = require('express');
var router = express.Router();
// 七牛云模块
const qiniu = require('qiniu')
const {Ak,Sk} = require('../config/index')

router.get('/uploadToken',(req,res)=>{
    // 构建鉴权对象
    const mac = new qiniu.auth.digest.Mac(Ak, Sk);
    const options = {
        scope: 'nvb-blog',
    };
    const putPolicy = new qiniu.rs.PutPolicy(options);
    const uploadToken = putPolicy.uploadToken(mac);
    res.json({
        code:200,
        data:uploadToken,
        msg:"success"
    })
})

module.exports = router

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值