如何使用NodeJS删除文件



我有两个异步函数:

  1. 一个用于在PostgreSQL中创建对象并在该对象中上载名为的文件的程序
  2. 另一个用于删除此实体和从文件夹中删除文件的实体

我不知道如何从PostgreSQL实体中提取文件名,并删除我的"静态"文件夹中的某些文件

PostgreSQL中的实体看起来像:

Car:
{
'name': 'Nissan 350Z',
'description': 'new',
'image': '123wejdsefberfkj.jpg',
'video': '23rusdjf8ioysdfs.mp4'
}

创建功能:

在这里我从表单数据中获取文件,为文件创建唯一的名称并将其保存在PostgreSQL中,然后我将文件保存在"静态";文件夹

let videoName = uuid.v4() + '.mp4';
let imageName = uuid.v4() + '.jpg';
let {name,description} = req.body;
const {video, image} = req.files; 
const car = await Car.create( {name, description, video: videoName,image: imageName})
.then(video.mv(path.resolve(__dirname,'..', 'static', videoName)))
.then(image.mv(path.resolve(__dirname,'..', 'static', imgName)))

删除功能:

在这里,我需要从数据库中提取文件名,并从文件夹中删除它们

一位伪代码:

async delete(req, res) {
try {
const {id} = req.params;
await Car.findOne({where:{id}})
.then( async data => {
if(data) {
await let videoName = Car.@extract_video_name@ ({where: {id}})
.then(mv(path.delete(__dirname,'..','static',videoName)))
await Car.destroy({where:{id}}).then(() => {
return res.json("Car deleted");
})
} else {
return res.json("This Car doesn't exist in database");
}
})

} catch (e) {
console.error(e)
}
}

您可以使用fs,需要使用const fs = require('fs');

您没有要安装的npm包,它包含在node.js.中

这是一个代码,允许您通过创建文件夹将文件保存到目录中(如果文件夹不存在(,并将文件上传到中

let path = String(`./directoryName/${fileName}`);
fs.mkdirSync('./directoryName', { recursive: true });
fs.writeFileSync(path, data);

您可以使用删除文件

fs.unlink(path, (err) => {
if (err) throw err //handle your error the way you want to;
console.log('path/file.txt was deleted');//or else the file will be deleted
});
);

参考:https://nodejs.org/api/fs.html

最新更新