body-parser和multer
来源:互联网 发布:如何搭建家庭光纤网络 编辑:程序博客网 时间:2024/05/18 04:12
新版的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
- body-parser和multer
- express和body-parser的登录项目
- express body-parser
- express插件之body-parser
- npm body-parser 中文api
- Express中间件之body-parser
- Cannot find module 'body-parser'
- npm body-parser 中文api
- Express 常用中间件 body-parser 实现解析
- nodejs使用body-parser解析表单数据
- node.js的body-parser中间件
- body-parser Node.js(Express) HTTP请求体解析中间件
- express中间件body-parser实现拿到post请求的数据
- Nodejs进阶:Express常用中间件body-parser实现解析
- Nodejs 进阶:Express 常用中间件 body-parser 实现解析
- Nodejs 进阶:Express 常用中间件 body-parser 实现解析
- nodejs +body parser接收 base64并保存图片
- FormData和multer使用的一个小坑
- 正则表达式
- LoadRunner中负载时间Duration与迭代次数Iteration的联系
- LINK - About Cache Control of Azure Blob Files
- linux grep 命令
- C++ string学习
- body-parser和multer
- 出货后还在stage的so
- C++11标准后的C++阅读书目
- cpu指令如何读写硬盘
- int与Integer的区别!
- ubuntu和virtualbox之间设置共享目录
- Prezi
- 导航控制器的使用
- iOS开发42-iOS Swift简单介绍