我有两个异步函数:
- 一个用于在PostgreSQL中创建对象并在该对象中上载名为的文件的程序
- 另一个用于删除此实体和从文件夹中删除文件的实体
我不知道如何从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