Я пытаюсь написать функцию, которая будет удалять файлы в каталоге, возраст которого превышает 1 день.В настоящее время моя логика такова:
- читать все файлы в каталоге и помещать их в массив
- для каждого файла, проверять разницу между текущим
ctime
и файлом ctime
больше 1 дня - если да, то удалите его
- проверьте следующий файл в массиве
Мой код для выполнения вышеприведенного приведен ниже:
var fs = require('fs');
var path = require('path');
var uploadsDir = __dirname + '/uploaded_files'
fs.readdir(uploadsDir, function(err, files) {
var removedFiles = [];
files.forEach(function(file, index) {
filePath = path.join(uploadsDir, file);
console.log(filePath);
fs.stat(filePath, function(err, stat) {
if (err) {
return console.error(err);
}
var now = new Date();
var endTime = new Date(stat.ctime);
var diffDays = parseInt((now - endTime) / (1000 * 60 * 60 * 24))
console.log(now);
console.log(endTime);
console.log(diffDays + ' days');
if (diffDays >= 1) {
fs.unlink(filePath, function(err) {
if (err) {
return console.log(err);
}
});
removedFiles.push(file)
console.log(filePath + ' has been removed!');
console.log(file);
console.log('\n');
}
}); // end of fs.stat
}); // end of forEach
});
Пока мой код был успешным только при удалении last файла в массиве someotherfile.png
.Затем он начинает жаловаться так:
/Users/username/api/uploaded_files/.DS_Store
/Users/username/api/uploaded_files/anotherfile.png
/Users/username/api/uploaded_files/somefile.png
/Users/username/api/uploaded_files/someotherfile.png
2018-06-06T09:21:30.010Z
2018-06-04T21:50:33.546Z
1 days
/Users/username/api/uploaded_files/someotherfile.png.png has been removed!
.DS_Store
2018-06-06T09:21:30.012Z
2018-06-04T21:50:46.509Z
1 days
/Users/username/api/uploaded_files/someotherfile.png has been removed!
anotherfile.png
2018-06-06T09:21:30.012Z
2018-06-04T21:50:46.508Z
1 days
/Users/username/api/uploaded_files/someotherfile.png has been removed!
somefile.png
{ Error: ENOENT: no such file or directory, unlink '/Users/username/api/uploaded_files/somefile.png'
errno: -2,
code: 'ENOENT',
syscall: 'unlink',
path: '/Users/username/api/uploaded_files/somefile.png' }
{ Error: ENOENT: no such file or directory, unlink '/Users/username/api/uploaded_files/somefile.png'
errno: -2,
code: 'ENOENT',
syscall: 'unlink',
path: '/Users/username/api/uploaded_files/somefile.png' }
{ Error: ENOENT: no such file or directory, unlink '/Users/username/api/uploaded_files/somefile.png'
errno: -2,
code: 'ENOENT',
syscall: 'unlink',
path: '/Users/username/api/uploaded_files/somefile.png' }
Может кто-нибудь сказать мне, что не так?