如何使强大的不保存到nodejs和Express应用程序上的var /文件夹

问题描述

我正在使用强大的解析传入文件并将其存储在AWS S3中

当我调试代码时,我发现强大的功能首先将其保存到/ var / folders /的磁盘上,并且随着时间的推移,一些不必要的文件会堆积在磁盘上,这可能在以后导致大问题。

我现在对代码完全不了解,对我来说却很愚蠢

我必须弄清楚如何在将解析后的文件保存到S3后删除文件,或者将其保存到s3而又不将其存储在磁盘中。 但是问题是我该怎么办?

如果有人能指出我正确的方向,我将不胜感激

这是我处理文件的方式:

import formidable,{ Files,Fields } from 'formidable';

const form = new formidable.IncomingForm();
form.parse(req,async (err: any,fields: Fields,files: Files) => {
let uploadUrl = await util
            .uploadToS3({
                file: files.uploadFile,pathName: 'myPathName/inS3',fileKeyName: 'file',})
            .catch((err) => console.log('S3 error =>',err));
}

解决方法

这是我解决此问题的方法:

当我解析传入的表单多部分数据时,我可以访问文件的所有详细信息。因为它已经被解析并保存到服务器/我的计算机的本地磁盘上。因此,使用强大的路径变量,我使用节点的内置fs.unlink函数取消链接/删除该文件。当然,我将文件保存到AWS S3之后将其删除。

这是代码:

import fs from 'fs';
import formidable,{ Files,Fields } from 'formidable';

const form = new formidable.IncomingForm();
form.multiples = true;

form.parse(req,async (err: any,fields: Fields,files: Files) => {
   const pathArray = [];
   try {
      const s3Url = await util.uploadToS3(files);
      // do something with the s3Url
      pathArray.push(files.uploadFileName.path);
   } catch(error) {
      console.log(error)
   } finally {
      pathArray.forEach((element: string) => {
         fs.unlink(element,(err: any) => {
            if (err) console.error('error:',err);
            });
        });
   }
})

我还找到了一个解决方案,您可以查看here,但是由于该体系结构,如果发现它很难在不更改原始代码的情况下实现(或者只是说我不完全理解给定的代码)实施)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...