1.下载包
npm i formidable
2.传入形式
传递options给函数/构造函数,而不要将其分配给实例form
四种任选一种即可
const formidable = require('formidable');
const form = formidable(options);
// or
const { formidable } = require('formidable');
const form = formidable(options);
// or
const { IncomingForm } = require('formidable');
const form = new IncomingForm(options);
// or
const { Formidable } = require('formidable');
const form = new Formidable(options);
3.英雄案例后台-文件上传
1.引入formidable模块 const formidable = require(‘formidable’);
2.创建解析对象 const form = new formidable.IncomingForm();
3.设置文件上传路径 form.uploadDir = path.join(__dirname, ‘/public/images’);
4.是否保留上传文件的后缀名 form.keepExtensions = true;
5.解析表单 form.parse(req, (err, fields, files) => {})
// 引入实现文件上传的模块
const { IncomingForm } = require('formidable')
const path = require('path')
module.exports = {
// 实现文件上传
uploadFile: function (req, res) {
// 1.创建文件上传对象
let form = new IncomingForm()
// 2.添加必要的配置
// 2.1 设置编码,formidable也可 接收普通键值对,这个时候就有需要设置编码,如果只是上传文件,则不用设置
// form.encoding = 'utf-8'
// // 2.2 设置上传文件的存放路径,一定给一个全路径,否则报错
form.uploadDir = __dirname + '/public/images'
// // 2.3 设置是否保留文件的扩展名,默认不保留
form.keepExtensions = true
// 3.调用上传方法,实现文件上传
// form.parse(请求报文,回调函数)
// err:文件上传失败时的错误信息
// fields:接收到普通键值对--对象
// files:文件的相关信息,特别是上传成功后在服务器端的信息
form.parse(req, (err, fields, files) => {
if (err) {
console.log(err)
res.json({
code: 204,
msg: '文件上传失败'
})
} else {
res.json({
code: 200,
msg: '文件上传成功',
img: path.basename(files.img.path)
})
}
})
},
}