七牛文件上传js和node

公司经常会用到七牛上传,用工具和网页上传总是很慢需要找对应路径和刷新cdn,看到官方有js的api就自己做了个批量上传和刷新cdn功能

获取七牛token,必须服务端,不能前端获取,所以自己用node写

先安装

cnpm i qiniu --save

获取token代码

  let qiniu = require('qiniu')
  let config = require('./config.js')
  let key="img/abc.png"  //文件线上的地址 比如 img/abc.png
  let mac = new qiniu.auth.digest.Mac(config.access_key, config.secret_key);
  let options = {
    scope: config.bucket + ":" + decodeURIComponent(key)
  }
  // 获取token
  let putPolicy = new qiniu.rs.PutPolicy(options);
  let uploadToken=putPolicy.uploadToken(mac);
  return uploadToken

前端部分,用的vue

<input ref="file" type="file" multiple accept=".apk,.ipa" style="display: none" @change="upload">

	upload(e) {
      // 批量上传上传
      this.progress = []
      for(let item of e.target.files) {
        this.uploadprocess(item)
      }
    },
    uploadprocess(file) {
      let _this = this;
      const key = `img/${file.name}`;
      this.$http('获取token地址', {
        key
      }).then(({data}) => {
        const token =data.data  //拿到token
        const putExtra = {
          fname: '',  //文件原文件名
          params: {}, //用来放置自定义变量
          mimeType: null, //用来限定上传文件类型,指定null时自动判断文件类型
        };
        const config = {
          useCdnDomain: true, //使用cdn加速
          region: qiniu.region.z0,
        };
        const observable = qiniu.upload(file, key, token, putExtra, config);
        observable.subscribe({
          next: (result) => {
          console.log(result)   //显示进度 自己写样式
          },
          error: () => {
            this.$Message.error('上传失败')
          },
          complete: (res) => {
            console.log(res.key);
          },
        });
      })
    }

上传完了 还要刷新七牛cdn,服务端node实现

  let url = ""  //完整的域名加路径  比如https://baidu.com/img/
  var mac = new qiniu.auth.digest.Mac(config.access_key, config.secret_key);
  var cdnManager = new qiniu.cdn.CdnManager(mac);
  cdnManager.refreshDirs([url], function (err, respBody, respInfo) {
    if (err) {
      console.log(err)
      throw err;
    }
    console.log('七牛刷新目录成功')
  });

其他细节可以自己封装

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值