【Express】文件上传管理 multer 中间件

Multer是Node.js中用于处理文件上传的中间件。它可以帮助你处理文件上传的相关逻辑,如接收和保存上传的文件、限制文件大小、设置文件类型限制等。只能用于处理 multipart/form-data 类型的表单数据,它主要用于上传文件。

下面是使用Multer中间件的基本步骤:

  1. 安装multer:在命令行中运行npm install multer来安装multer模块。

  2. 导入multer模块和创建multer实例:在你的Node.js应用程序中,使用require语句导入multer模块,并创建一个multer实例。

javascript 复制代码
const multer = require('multer');
const upload = multer({ dest: 'uploads/' });

上述代码中,我们使用multerdest属性指定上传文件的保存目录。

  1. 创建路由处理程序:在你的路由处理程序中,使用upload中间件来处理文件上传请求。
javascript 复制代码
app.post('/upload', upload.single('file'), (req, res) => {
  // 文件上传成功后的操作
});

上述代码中,我们使用upload中间件的single方法指定只处理单个文件上传请求。'file'参数是表单中文件输入字段的name属性值。

  1. 处理上传成功的文件:在文件上传成功后的处理程序中,可以通过req.file对象获取上传的文件信息。

Multer 会添加一个 body 对象 以及 filefiles 对象 到 express 的 request 对象中。 body 对象包含表单的文本域信息,filefiles 对象包含对象表单上传的文件信息。

javascript 复制代码
app.post('/upload', upload.single('file'), (req, res) => {
  if (req.file) {
    // 文件上传成功
    console.log('File uploaded:', req.file);
  } else {
    // 没有文件上传
    console.log('No file uploaded');
  }
});

上述代码中,req.file对象将包含上传文件的详细信息,如文件名、文件大小、文件路径等。

Multer还提供了其他一些常用方法和选项,例如array方法可以处理多个文件上传请求,fields方法可以处理不同字段名的文件上传请求,limits选项可以设置文件大小限制等。

js 复制代码
// 前端
const params = new FormData()
params.append('avatar', avatar.files[0])
params.append('username', username.value)
const config = {
	headers: {
		"Content-Type":"multipart/form-data"
	}
}
http.post('/api/upload', params, config).then(res => {
	this.imgpath = 'http://localhost:3000' + res.data
})	
相关推荐
fangzt201019 小时前
从零搭建自动驾驶中间件(二):共享内存零拷贝通信的工程实践
人工智能·中间件·自动驾驶
fangzt20101 天前
从零搭建自动驾驶中间件(三):事件驱动与协程调度的工程实践
人工智能·中间件·自动驾驶
fangzt20101 天前
从零搭建自动驾驶中间件(五):状态机、诊断与运维——让系统“可观测、可控制“
中间件·自动驾驶
fangzt20101 天前
从零搭建自动驾驶中间件(四):数据录制与回灌——算法调试的核心基础设施
算法·中间件·自动驾驶
fangzt20101 天前
从零搭建自动驾驶中间件(一):为什么自动驾驶需要自研中间件
人工智能·中间件·自动驾驶
好奇的菜鸟2 天前
Java开发常用中间件,Docker安装。
java·docker·中间件
qq_283720053 天前
LangChain 动态模型中间件实战使用技巧
中间件·langchain·middleware·wrap_model_call
Json____3 天前
node-电商商城平台实战项目(管理端+用户端)
node·vue2·express·element-ui·电商商城
晚风_END3 天前
Linux|操作系统|最新版openzfs编译记录
linux·运维·服务器·数据库·spring·中间件·个人开发
星光开发者4 天前
基于springboot电动汽车租赁管理系统-计算机毕设 附源码 11217
javascript·spring boot·mysql·django·php·html5·express