七牛文件上传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('七牛刷新目录成功')
});