问题描述
我正在使用强大的解析传入文件并将其存储在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,但是由于该体系结构,如果发现它很难在不更改原始代码的情况下实现(或者只是说我不完全理解给定的代码)实施)