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是你存储空间的对应的机房, 测试时候发现,填错七牛会提示你是哪个机房
