узел js - fs.unlink удаляет только первый файл в последовательности forEach, затем выбрасывает ENOENT, нет такого файла или каталога - PullRequest
0 голосов
/ 06 июня 2018

Я пытаюсь написать функцию, которая будет удалять файлы в каталоге, возраст которого превышает 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' }

Может кто-нибудь сказать мне, что не так?

1 Ответ

0 голосов
/ 06 июня 2018

Оказывается, я пропустил объявление filePath в качестве переменной.Благодаря @ CertainPerformance.

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) {
        var filePath = path.join(uploadsDir, file); //added this var here and it works now!
        console.log(filePath);
...