node上传文件到个人七牛云
最近公司项目需求比较少,终于有时间闲下了学习点新的。前段时间研究了框架koa2, 刚好有一些文件需要上传到七牛云,趁热打铁,结合koa2框架看看如何上传文件到七牛。
先上效果图
前端
前端渲染用到Vue, 监听input(file) 的change事件, 表单上传使用FormData1
2
3
4
5
6<div class="form-action clearfix">
<a class="zh-btn zh-btn--primary">
上传图片
<input class="native-input-file" type="file" name="file" @change="onChangeFile"/>
</a>
</div>
1 | var vm = new Vue({ |
后端
后端处理是先将文件上传到node,在上传文件至七牛云
文件上传到node
这里用到了busboy, 一个转换表单数据的库,接着就是读写文件到node服务相应目录下1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33/**
* 上传到本地
*/
const uploadLocal = (ctx, options) => {
const _emmiter = new Busboy({headers: ctx.req.headers})
const fileType = options.fileType
const filePath = path.join(options.path, fileType)
const confirm = fsUtil.mkdirsSync(filePath)
if (!confirm) return
return new Promise((resolve, reject) => {
_emmiter.on('file', function (fieldname, file, filename, encoding, mimetype) {
const fileName = Rename(filename)
const saveTo = path.join(path.join(filePath, fileName))
file.pipe(fs.createWriteStream(saveTo))
file.on('end', function () {
resolve({
imgPath: `/${fileType}/${fileName}`,
imgKey: fileName
})
})
})
_emmiter.on('finish', function () {
console.log('finished...')
})
_emmiter.on('error', function (err) {
console.log('err...')
reject(err)
})
ctx.req.pipe(_emmiter)
})
}
node上传文件到七牛云
这个网上的例子很多,很多例子比较旧,最好的还是看官方的文档。七牛node传送门
先解释几个概念, 可以单独放在你的配置文件中
1 | const config = { |
accessKey/secretKey
bucket
1 上传代码
1 | /** |
这个注意:qiniu.zone.Zone_z0是你存储空间的对应的机房, 测试时候发现,填错七牛会提示你是哪个机房