小编给大家分享一下Nodejs +表达中间件实现文件上传的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获、下面让我们一起去了解一下吧!
用Nodejs做项目时需要用到文件上传的功能,在网上搜索了很多教程,找到了一个表达的中间件,用于处理<代码>多部分/格式> 代码类型的表单数据,可以很方便的将表单中的文件数据保存到服务器。
介绍
<人力资源/>乘是一个节点。js文件上传中间件,它是在餐馆工的基础上开发的,上传的表单数据必须是<代码>多部分/格式> 代码类型,不然会报错。
简单的用法
<人力资源/> <强>定义存储器强>
乘作为表达的一个中间件,我们可以很方便的自定义上传的文件目录以及保存的文件名。先看一个最简单的用法,demo1地址:
var express =,要求(& # 39;表达# 39;); var multer =,要求(& # 39;multer& # 39;); var app =,表达(); var upload =,乘({ 存储:,,,,multer.diskStorage ({ ,,,,,,,目的地:,function (点播,,文件,,cb), { ,,,,,,,,,,,cb (null, & # 39;。/上传/& # 39;); ,,,,,,,}, ,,,,,,,文件名:,function (点播,,文件,,cb), { ,,,,,,,,,,,//file.originalname上传文件的原始文件名 ,,,,,,,,,,,var changedName =, (new 日期().getTime ()) + & # 39; & # 39; + file.originalname; ,,,,,,,,,,,cb (null,, changedName); ,,,,,,,} ,,,}) });
我们先创建了一个上传对象,这个对象中目的地函数用来定义上传文件的存储的文件夹;文件名函数用来修改上传文件存储到服务器的文件名称,这里我们我们加上一个时间戳简单区分一下。这两个函数都是通过回调函数来实现的。每次上传的时候这两个函数都会调用一次,如果是多个文件上传,那个这两个函数就调用多次,调用顺序是先调用目的地,然后调用文件名。
在两个函数中都会有一个文件<代码> 代码>对象,表示当前上传的文件对象,有以下几个属性:
- <李>
fieldname:上传的字段名
李> <李>originalname:上传的文件名
李> <李>编码:文件的编码类型
李> <李>mimetype:文件的MIME类型
李>附:一些常用的MIME类型
<强>定义路由回调强>
//单个文件上传 app.post(& # 39;/上传/单# 39;,upload.single (& # 39; singleFile& # 39;),(要求,res)=祝辞{ ,,,console.log (req.file); ,,,res.json ({ ,,,,,,,代码:,& # 39;0000 & # 39; ,,,,,,,类型:& # 39;单# 39; ,,,,,,,originalname: req.file.originalname ,,,}) });//多个文件上传 app.post(& # 39;/上传/multer& # 39;, upload.array (& # 39; multerFile& # 39;),(要求,res)=祝辞{ ,,,console.log (req.files); ,,,let fileList =, []; ,,,req.files.map ((elem)=祝辞{ ,,,,,,,fileList.push ({ ,,,,,,,,,,,originalname: elem.originalname ,,,,,,,}) ,,,}); ,,,res.json ({ ,,,,,,,代码:,& # 39;0000 & # 39; ,,,,,,,类型:& # 39;multer& # 39; ,,,,,,,文件列表:文件列表 ,,,}); });
在表达中定义路由的回调函数时,把定义好了的上传对象作为中间件添加进去。如果是单个文件就用<代码>单> 代码方法,如果是多个文件就用数组<代码> 代码>方法,这两个方法都需要传一个页面上定义好的字段名。
在路由的回调函数中,请求对象已经有了文件属性(单个文件上传)或文件属性(多个文件上传),文件属性是一个数组,数组的每一个对象都有以下属性:
- <李>
fieldname:上传的字段名
李> <李>originalname:上传的文件名
李> <李>编码:文件的编码类型
李> <李>mimetype:文件的MIME类型
李> <李>目的地:存储的目录(和目的地回调函数中的目录名一致)
李> <李>文件名:保存的文件名和文件名(回调函数中的文件名一致)
李> <李>路径:保存的相对路径
李> <李>大小:文件的大小(单位:字节字节)
李>我们可以发现在路由的回调函数中的文件对象比diskStorage中的文件对象多了几个属性,这是因为在diskStorage中文件还没有保存,只能知道文件的大致属性;而路由的回调函数文件已经在服务器上保存好了,文件的保存路径以及文件的大小都是已知的。
<强>混合上传强>
有时候我们可能需要用字段名来对上传的文件进行一下划分,比如说上传多个图片的时候可能有身份证还有头像。虽然可以分开放到两个接口中,但是会产生其他一系列的麻烦事.multer支持对图片进行字段名的划分.demo3地址