NodeJS 和 Multer:如果发生错误则停止上传文件

ili*_*ia1 6 javascript upload file-upload node.js multer

你好,我使用 Node 和 Multer 创建文件上传,它可以工作,但问题是,如果发生错误(例如用户没有填写其他字段),它仍然会上传我不想要的文件

我真的不知道该怎么做,因为我是第一次这样做,所以希望有人有这方面的经验。这是我的代码

const storage = multer.diskStorage({

  destination: (req, file, callback) => {
    const userPath = path.join(imgStoragePath, req.userId);
    fs.mkdir(
      userPath,
      () => callback(null, userPath)
    )
  },

  filename: (req, file, callback) => {
    const filenameParts = file.originalname.split('.');
    const ext = filenameParts.pop();
    const basename = filenameParts.join('.');
    const additionalPath = Date.now() + '' + uuid() + '' +             
Math.floor(Math.random() * (2000 - 500)) + 500;
    callback(null, basename + '-' + additionalPath + '.' + ext);
  }

})

const upload = multer({
  storage,
  limits: '1mb'
})


   router.post('/', upload.single('image'), async (req, res) => {
  //code
})
Run Code Online (Sandbox Code Playgroud)

如果发生错误,它应该返回错误消息并将其发送到服务器并停止代码执行,并且不执行任何操作,它会执行此操作,但也会上传文件,我知道会发生这种情况,因为upload中间件和中间件首先执行,我希望它阻止它。谢谢!

Jud*_*des 3

好的,multer 并不真正负责验证您的表单输入,它的唯一目的是允许您将文件上传到后端。现在开始讨论您要解决的问题

  • 您可以在前端进行 html 验证,以确保用户required在提交表单之前填写所有字段
  • 您可以进行后端检查以确保所有必填字段均已填写

为了使用第二步,您可以使用这样的函数

 export const setRequired = (...args: any): boolean => {
   let isValid = true;
   _.forEach(args, value => {
     if (isUndefined(value)) isValid = false;
   });
   return isValid;
 };
Run Code Online (Sandbox Code Playgroud)
 export const setRequired = (...args: any): boolean => {
   let isValid = true;
   _.forEach(args, value => {
     if (isUndefined(value)) isValid = false;
   });
   return isValid;
 };
Run Code Online (Sandbox Code Playgroud)

该函数使用 typescript 和 lodash 并检查所有指定的参数是否存在。因此,在后端执行任何操作之前,请将必填字段传递给函数,该函数将返回一个布尔值,以通知您是否已从前端收到所有必填字段。

关于与 multer 文件大小和文件类型错误相关的第二部分,您可以尝试这样的操作

 const isValid: any = setRequired(file, first_name, last_name);
Run Code Online (Sandbox Code Playgroud)
 const storage = multer.diskStorage({
 destination(req, file, cb) {
   cb(null, path.join(__dirname, `path_to_folder`));
 },
 filename(req, file, cb) {
   const ext = path.extname(file.originalname).toLowerCase();
   const file_name = uuidv4() + "_" + ext;
   cb(null, file_name);
 },
});

const upload = multer({
 storage,
 limits: { fileSize: 2000000 }, // In bytes: 2000000 bytes = 2 MB
 fileFilter(req, file, cb) {
   const ext = path.extname(file.originalname).toLowerCase();
   if (ext !== ".png" && ext !== ".jpg" && ext !== ".jpeg") {
     cb(new Error("Error: Unacceptable file format"), false);
   } else {
     cb(null, true);
   }
 },
}).any();
Run Code Online (Sandbox Code Playgroud)