多访问 req.body 无需上传文件

Multer access req.body without uploading files

我有一个表单,其中包含一些不能为空的文本字段和文件输入,我想先对文本字段执行一些操作(添加到数据库),如果这些操作成功,则上传文件。这是我现在的代码:

var multer = require('multer');
var getFields = multer();
router.post('/add',getFields.array(),function(req,res){
var artist = new ArtistModel({
            name : req.body.name.toLowerCase(),
            description:req.body.description,
          });

然后我将艺术家添加到我的数据库中,在成功的回调中我希望上传文件。但是问题是我不能简单地使用 getFields.array() 因为我有文件输入并且我得到 "Unexpected fields" 错误,如果我不使用 .array() 我将无法获得 post 请求正文。无论如何先获取带有 enctype="multipart/form-data" 的表单文本字段,然后再上传文件?

更新 #2 感谢 Dave 我能够在不上传文件的情况下获取文本字段,我成功地将我的艺术家添加到我的数据库中,但是之后我不知道如何上传文件, 我在 addToDb 的回调函数中创建了一个新变量:

var storage = multer.diskStorage({
            destination: function (req, file, cb) {
              //cb(null, 'artistsMedia/drake/songs')
              var dir = 'artistsMedia/' + req.body.name.toLowerCase()+ '/images';
              mkdirp(dir,err => cb(err,dir))
            },
            filename: function (req, file, cb) {
              cb(null, req.body.name.toLowerCase() +'-'+ file.fieldname +'-'+ Date.now() + path.extname(file.originalname)) //Appending extension
            },

          });
          var upload = multer({
            storage: storage,
            limits :{fileSize :52428800}
          }).fields([{name:'Logo',maxCount:1},{name:'artistHome',maxCount:1},{name:'otherImgs',maxCount:10}]);

但是调用 upload(req,res,err) 似乎不起作用。

尝试使用 multer 的 any() 函数:

var multer = require('multer');
var getFields = multer();
router.post('/add',getFields.any(),function(req,res){
  // any files, if sent, will be in req.files 
  var artist = new ArtistModel({
    name : req.body.name.toLowerCase(),
    description:req.body.description,
  });
});

如果您确定不会提交任何文件,请使用 multer 的 none() 功能:

var multer = require('multer');
var getFields = multer();
router.post('/add',getFields.none(),function(req,res){
  // uploading files will cause an error
  var artist = new ArtistModel({
    name : req.body.name.toLowerCase(),
    description:req.body.description,
  });
});