您的位置:首页 > 其它

body-parser和multer

2015-11-23 19:38 218 查看
新版的nodejs中的body-parser和multer中间件进行了改写,而很多教程都是旧的同时这几天看到一个篇文章,大概意思是说,关于node的一本教程,刚上市就过时了.是的,这就是js,各种新技术,各种新的插件的更新速度简直了!!!!

我来整理一下关于这两个插件的最新版的用法,因为没有找到详细的教程,只能到npmjs上面查看文档了.可能很多新同学看到满篇的英文就觉得头大.但是只要你下决心去看的话,就会发现,其实和看中文的教程是没什么差别的.

先看multer,它的第一句介绍是:一个关于multipart/form-data上传的中间件(其中multipart/form-data是浏览器通过表单上传文件的一种方式,比如:邮件附件,关于它的有关知识可以百度,此处不作过多解释.),主要用来上传文件

安装

npm install --save multer


使用

Multer会把body,或者file/files对象,添加到request对象中.body对象包含有表单中提交的文本数据,file/files对象包含有你通过表单上传的文件.

几个使用的实例

var express = require('express')
var multer = require('multer')
var upload = multer({dest:'upload/'})
/*几乎在所有的web app中,dest属性都是必须的,一般它的使用形式如上.

*/

var app = express()

app.post('/profile', upload.single('avatar'), function (req, res, next) {
// req.file is the `avatar` file
// .single只能接收一个文件,文件将会被保存在req.file中,下同
})

app.post('/photos/upload', upload.array('photos', 12), function (req, res, next) {
// req.files is array of `photos` files
// .array可以接受一组文件,如果文件数超过12个就会报错
})

var cpUpload = upload.fields([{ name: 'avatar', maxCount: 1 }, { name: 'gallery', maxCount: 8 }])
app.post('/cool-profile', cpUpload, function (req, res, next) {
// req.files is an object (String -> Array) where fieldname is the key, and the value is array of files
//
// e.g.
//  req.files['avatar'][0] -> File
//  req.files['gallery'] -> Array
//
// req.body will contain the text fields, if there were any
})


如果你想对你upload的文件进行更多的操作,可以使用storage而不是dest.Multer提供了两个storage引擎

1. DiskStorage

var storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, '/tmp/my-uploads')
},
filename: function (req, file, cb) {
cb(null, file.fieldname + '-' + Date.now())
}
})

var upload = multer({ storage: storage })


destination:文件上传的目的路径,虽然不配置这个参数,文件将会自动上传到操作系统默认的tem/uploads文件夹中.但是为了避免不必要的麻烦,一定要写上自己知道的路径

filename:文件上传后在服务器端的名字,建议改名,那样可以避免一定的主动攻击

2. MemoryStorage

顾名思义,这个会把文件保存在内存里,当作Buffer对象,他没有任何的可选参数

var storage = multer.memoryStorage()

var upload = multer({ storage: storage })


body-parser

urlencoded({extended:true});返回一个解析过的url,被解析的url必须是utf-8格式.

,则返回一个k-v键值对,如果是false,则返回一个字符串或者数组.如果extended为true,则返回任意type

参考来自

https://www.npmjs.com/package/multer
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: