欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

七牛文件上传js和node

程序员文章站 2022-04-18 13:53:28
...

公司经常会用到七牛上传,用工具和网页上传总是很慢需要找对应路径和刷新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('七牛刷新目录成功')
  });

其他细节可以自己封装

相关标签: node 七牛sdk