body-parser和multer
2015-11-23 19:38
218 查看
新版的nodejs中的body-parser和multer中间件进行了改写,而很多教程都是旧的同时这几天看到一个篇文章,大概意思是说,关于node的一本教程,刚上市就过时了.是的,这就是js,各种新技术,各种新的插件的更新速度简直了!!!!
我来整理一下关于这两个插件的最新版的用法,因为没有找到详细的教程,只能到npmjs上面查看文档了.可能很多新同学看到满篇的英文就觉得头大.但是只要你下决心去看的话,就会发现,其实和看中文的教程是没什么差别的.
先看multer,它的第一句介绍是:一个关于multipart/form-data上传的中间件(其中multipart/form-data是浏览器通过表单上传文件的一种方式,比如:邮件附件,关于它的有关知识可以百度,此处不作过多解释.),主要用来上传文件
几个使用的实例
如果你想对你upload的文件进行更多的操作,可以使用storage而不是dest.Multer提供了两个storage引擎
1. DiskStorage
destination:文件上传的目的路径,虽然不配置这个参数,文件将会自动上传到操作系统默认的tem/uploads文件夹中.但是为了避免不必要的麻烦,一定要写上自己知道的路径
filename:文件上传后在服务器端的名字,建议改名,那样可以避免一定的主动攻击
2. MemoryStorage
顾名思义,这个会把文件保存在内存里,当作Buffer对象,他没有任何的可选参数
,则返回一个k-v键值对,如果是false,则返回一个字符串或者数组.如果extended为true,则返回任意type
参考来自
https://www.npmjs.com/package/multer
我来整理一下关于这两个插件的最新版的用法,因为没有找到详细的教程,只能到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
相关文章推荐
- 设计模式-结构型模式
- linux grep 命令
- 正则表达式
- 设计模式-创建型模式
- foreach遍历对象的属性
- STM32栈和堆使用不同RAM的实现方法
- ios autolayout
- 【人月神话】第一章:焦油坑
- Linux部分命令概括
- Revit二次开发--"Add Hello World Ribbon Panel"
- ar list
- mongodb使用备忘
- 服务器架设笔记——多模块和全局数据
- IOS开发基础Object-C(09)—OC内存管理(3)-@property的参数详解
- SaaS应用“超级表格”获数百万天使融资
- 转载 Url编码
- Spring下mybatis多数据源配置
- 如何删除数组中不需要的数据
- Iterator(迭代器)接口 --对象循环遍历
- 腾云驾雾了解Windows10和微软私有云