当前位置: 首页 > 工具软件 > formidable > 使用案例 >

formidable的基本使用

庞旺
2023-12-01

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)
        })
      }
    })
  },
}
 类似资料: