重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
本篇内容介绍了“怎么用node+multer中间件实现单文件、多文件上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联于2013年开始,先为城东等服务建站,城东等地企业,进行企业商务咨询服务。为城东企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
一、概念
Multer 是一个 node.js 中间件,用于处理 multipart/form-data 类型的表单数据,它主要用于上传文件。
注意: Multer 不会处理任何非 multipart/form-data 类型的表单数据。
二、安装
npm i multer --save
三、使用(页面底部有单文件、多文件上传案例)
Multer 会在express 的 request 对象里添加一个 body 对象 (包含表单的文本域信息)以及 file 或 files 对象 (单文件通过req.file获取,多文件通过req.files获取,file 或 files 对象包含对象表单上传的文件信息)。
四、基本使用
//1.引入依赖
const express = require('express')
const multer = require('multer')
//存储在uploads文件夹下面,没有会直接创建
const upload = multer({ dest: 'uploads/' })
const app = express()
//相同的
//以下fielname(字符串)必须前端传过来的myformData对象的属性名一致,不然后端接收不到这个文件对象 // req.body 将具有文本域数据,如果存在的话
app.post('/profile', upload.single(fielname), function (req, res, next) {
//multer实例.single(fielname)——单文件上传,文件对象获取通过req.file
//multer实例.single(fieldame)——接受一个以fielname命名的文件,这个文件的信息保存在req.file中的fielname属性
// req.body 将具有文本域数据,如果存在的话
})
app.post('/photos/upload', upload.array(fielname, 12), function (req, res, next) {
//multer实例.array(fielname[,maxCount])——接收一个以fielname命名的文件数组;maxCount——限制上传的最大数量,这些文件的信息保存在req.files里面
})
const cpUpload = upload.fields([{ name:fields[, maxCount: 1 ]}, { name: 'gallery', maxCount: 8 }])
//multer实例.files(fields)——接受指定fields的混合文件,获取——req.files
//fields应该是一个对象数组,应该具有name和可选的maxCount属性
app.post('/profile', upload.none(), function (req, res, next) {
//multer实例.none()——只接受文本域
})
“怎么用node+multer中间件实现单文件、多文件上传”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!