Правильный способ удалить все файлы старше 2 дней в PHP - PullRequest
36 голосов
/ 23 января 2012

Просто любопытно

        $files = glob(cacheme_directory()."*");
        foreach($files as $file)
        {
            $filemtime=filemtime ($file);
            if (time()-$filemtime>= 172800)
            {
                unlink($file);
            }
        }

Я просто хочу убедиться, что код правильный или нет.Спасибо.

Ответы [ 8 ]

82 голосов
/ 23 января 2012

Вы должны добавить проверку is_file(), поскольку PHP обычно перечисляет . и .., а также подкаталоги, которые могут находиться в каталоге, который выВы проверяете.

Кроме того, поскольку этот ответ предполагает , вы должны заменить предварительно рассчитанные секунды более выразительными обозначениями.

<?php
  $files = glob(cacheme_directory()."*");
  $now   = time();

  foreach ($files as $file) {
    if (is_file($file)) {
      if ($now - filemtime($file) >= 60 * 60 * 24 * 2) { // 2 days
        unlink($file);
      }
    }
  }
?>

В качестве альтернативы вы также можетеиспользуйте DirectoryIterator, , как показано в этом ответе .В этом простом случае это на самом деле не дает никаких преимуществ, но это будет ООП.

48 голосов
/ 12 декабря 2013

Самый простой способ - использовать DirectoryIterator :

<?php
if (file_exists($folderName)) {
    foreach (new DirectoryIterator($folderName) as $fileInfo) {
        if ($fileInfo->isDot()) {
        continue;
        }
        if ($fileInfo->isFile() && time() - $fileInfo->getCTime() >= 2*24*60*60) {
            unlink($fileInfo->getRealPath());
        }
    }
}
?>
9 голосов
/ 22 марта 2017

Другой, более простой и современный способ, с использованием FilesystemIterator .

В качестве примера я использую каталог 'logs'.

$fileSystemIterator = new FilesystemIterator('logs');
$now = time();
foreach ($fileSystemIterator as $file) {
    if ($now - $file->getCTime() >= 60 * 60 * 24 * 2) // 2 days 
        unlink('logs/'.$file->getFilename());
}

Основное преимущество:DirectoryIterator возвращает виртуальные каталоги "."и ".." в цикле.Но FilesystemIterator их игнорирует.

4 голосов
/ 23 января 2012

выглядит правильно для меня.Я бы просто предложил вам заменить 172800 на 2*24*60*60 для ясности.

2 голосов
/ 10 ноября 2017

Вот пример того, как сделать это рекурсивно.

function remove_files_from_dir_older_than_x_seconds($dir,$seconds = 3600) {
    $files = glob(rtrim($dir, '/')."/*");
    $now   = time();
    foreach ($files as $file) {
        if (is_file($file)) {
            if ($now - filemtime($file) >= $seconds) {
                echo "removed $file<br>".PHP_EOL;
                unlink($file);
            }
        } else {
            remove_files_from_dir_older_than_x_seconds($file,$seconds);
        }
    }
}

remove_files_from_dir_older_than_x_seconds(dirname(__file__).'/cache/', (60 * 60 * 24 * 1) ); // 1 day
2 голосов
/ 16 июня 2017
/* Delete Cache Files Here */
$dir = "cache/"; /** define the directory **/

/*** cycle through all files in the directory ***/
foreach (glob($dir."*") as $file) {
//foreach (glob($dir.'*.*') as $file){

/*** if file is 24 hours (86400 seconds) old then delete it ***/
if (filemtime($file) < time() - 172800) { // 2 days
    unlink($file);
    }
}

Надеюсь, это поможет вам.

2 голосов
/ 23 января 2012

Имейте в виду, что у вас возникнут проблемы, если в каталоге очень большое количество файлов.

Если вы считаете, что это может повлиять на вас, рассмотрите возможность использования подхода более низкого уровня, такого как opendir.

0 голосов
/ 21 июня 2017
/** It deletes old files.
 *  @param string $dir Directory
 *  @param int $secs Files older than $secs seconds
 *  @param string $pattern Files matching $pattern
 */
function delete_oldfiles($dir,$secs,$pattern = "/*")
{
    $now = time();
    foreach(glob("$dir$pattern") as $f) {
      if (is_file($f) && ($now - filemtime($f) > $secs)) unlink($f);
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...