- Работа с файлами в PHP
- Чтение файла: file()
- Создание файла и запись в файл: file_put_contents()
- Создание папки или структуры папок
- Проверка существования файла или папки
- Проверка прав доступа
- Копирование, перенос и удаление файла
- Работа с файлами с помощью fopen()
- mkdir
- Возвращаемые значения
- Ошибки
- Примеры
- Смотрите также
- User Contributed Notes 5 notes
- Создание, назначение доступа, удаление и проверка наличия папки в PHP
- Назначение прав при создании папки
- Создание нескольких вложенных поддиректорий
- Удаление папки
- Удаление непустой папки
- Проверка существования каталога
Работа с файлами в PHP
С помощью функции file_get_contents() можно получить содержимое файла:
Также мы можем получить html-код какой-либо страницы в интернете:
'; echo file_get_contents('https://ya.ru'); echo '';
Но работает это далеко не для всех сайтов, у многих есть защита от такого примитивного парсинга.
Чтение файла: file()
Функция file() позволяет получить содержимое файла в виде массива. Разделителем элементов является символ переноса строки.
Создадим в корне сайта файл data.txt со следующим содержимым:
Теперь запустим скрипт index.php со следующим кодом:
При запуске этого скрипта мы получим в браузере:
array(3) < [0]=>string(7) "Vasya " [1]=> string(7) "Petya " [2]=> string(5) "Gosha" >
Заметили, что у первых двух строк длина 7 символов вместо пяти? Это из-за того, что каждая строка содержит в конце символы переноса строки.
Чаще всего они нам не нужны, поэтому их можно убрать, передав вторым параметром константу FILE_IGNORE_NEW_LINES :
Теперь у всех строк будет по 5 символов.
Если нам необходимо получить только заполненные строки в файле и пропустить пустые, можно передать вторым параметром константу FILE_SKIP_EMPTY_LINES :
Разумеется, мы можем передать сразу две константы:
Создание файла и запись в файл: file_put_contents()
Функция file_put_contents() позволяет создать файл и заполнить его данными.
Первым параметром функция принимает путь к файлу, вторым — строку с данными. Для создания пустого файла нужно передать вторым параметром пустую строку.
Если файла не существует — он будет создан. Если существует — данные в файле будут перезаписаны.
Чтобы не перезаписывать данные, а добавить их в конец файла, нужно передать третьим параметром константу FILE_APPEND :
Также вторым параметром можно передать массив:
Но этот вариант не очень удобен, поскольку все элементы массива запишутся подряд, без каких-либо разделителей. Чтобы их добавить, можно использовать функцию implode:
Создание папки или структуры папок
Создать папку можно с помощью функции mkdir() (make directory):
Вторым параметром указываются права доступа к файлу в виде восьмеричного числа, по-умолчанию это 0777 , что означает самые широкие права. Для Windows этот аргумент игнорируется.
Кроме этого, второй параметр может игнорироваться при заданной umask (пользовательская маска (user mask), которая нужна для определения конечных прав доступа). В этом случае принудительно сменить права можно функцией chmod() :
Также мы можем создать структуру папок рекурсивно, для этого нужно третьим параметром передать true :
Но в этом случае права доступа будут заданы только для конечной папки. Для изменения прав у каждой из папок придётся указывать права вручную:
Права доступа — это отдельная объёмная тема, поэтому сейчас мы её пока рассматривать не будем.
Проверка существования файла или папки
Проверить существование папки или файла можно с помощью функции file_exists() :
Если вы хотите проверить существование только папки или только файла, для этого есть специальные функции is_dir() и is_file() :
Проверка прав доступа
Функции is_readable() и is_writable() проверяют, есть ли у пользователя, от имени которого запущен PHP, права на чтение и запись файла или папки:
Копирование, перенос и удаление файла
Для удаления файлов используется функция unlink() :
Чтобы скопировать файл, используем функцию copy() :
Для переименования и переноса файла в другую папку используется функция rename() :
Работа с файлами с помощью fopen()
Функций file() , file_get_contents() и file_put_contents() достаточно для решения большинства задач, связанных с управлением файлами.
Но иногда возникают ситуации, когда нам необходимы более продвинутые инструменты. Например, если у нас есть большой текстовый файл и мы хотим читать его построчно, а не весь сразу, для экономии оперативной памяти.
Итак, открыть (или создать и открыть) файл можно с помощью функции fopen() :
Функция fopen() возвращает так называемый лескриптор. Это ссылка, указатель на файл, его мы будем передавать в другие функции. Кстати, тип данных этого дескриптора — resource .
Первым параметром мы передаём путь к файлу, вторым — модификатор доступа к файлу. Ниже перечислены наиболее популярные модификаторы:
- r — открытие для чтения, указатель переходит в начало файла.
- r+ — открытие для чтения и записи, указатель переходит в начало файла.
- w — открытие для записи, указатель переходит в начало файла. Если файла нет — создаётся, если есть — очищается от данных.
- w+ — открытие для чтения и записи, в остальном аналогичен w .
- a — открытие для записи, указатель переходит в конец файла. Если файла нет — создаётся.
- a+ — открытие для чтения и записи, в остальном аналогичен a .
- x — создание и открытие для записи, указатель переходит в начало файла. Если файл существует — PHP покажет ошибку.
- x+ — создание и открытие для чтения и записи, в остальном аналогичен x .
Указатель — это нечто вроде курсора. Вы можете переместить его в любое место файла, чтобы добавить или отредактировать определённые данные.
Для записи данных в файл существует функция fwrite() . Давайте попробуем создать файл и записать в него какие-нибудь данные:
Заметьте, из-за модификатора w при каждом запуске скрипта данные в файле стираются и добавляются заново. Если модификатор заменить на a , данные будут не перезаписываться, а добавляться в конец файла.
Для построчного чтения файла используется функция fgets() :
При каждом запуске fgets получает следующую строку и возвращает её в $line . Вторым параметром передаётся максимальная длина строки. Это означает, что если строка слишком длинная, она будет обрезана.
Также в PHP существует множество других полезных функций, работающих с дескриптором файла. Почитать о них можно в документации.
mkdir
Для этой функции вы можете использовать URL в качестве имени файла, если была включена опция fopen wrappers. Смотрите более подробную информацию об определении имени файла в описании функции fopen() . Смотрите также список поддерживаемых обёрток URL, их возможности, замечания по использованию и список предопределённых констант в разделе Поддерживаемые протоколы и обёртки.
По умолчанию принимает значение 0777, что означает самые широкие права. Больше информации о правах доступа можно узнать на странице руководства функции chmod() .
Замечание:
Аргумент permissions игнорируется в Windows.
Обратите внимание, что аргумент permissions необходимо задавать в виде восьмеричного числа (первой цифрой должен быть ноль). На аргумент permissions также влияет текущее значение umask, которое можно изменить при помощи umask() .
Если указано значение true , то все родительские каталоги для указанного параметра directory также будут созданы, с теми же разрешениями.
Возвращаемые значения
Возвращает true в случае успешного выполнения или false в случае возникновения ошибки.
Замечание:
Если создаваемый каталог уже существует, это считается ошибкой и будет возвращено значение false . Используйте функцию is_dir() или file_exists() , чтобы проверить, существует ли уже каталог, прежде чем пытаться его создать.
Ошибки
Выдаёт ошибку уровня E_WARNING , если директория уже существует.
Выдаёт ошибку уровня E_WARNING , если соответствующие права доступа блокируют создание директории.
Примеры
Пример #1 Пример использования функции mkdir()
Пример #2 Использование mkdir() с параметром recursive
// Желаемая структура папок
$structure = ‘./depth1/depth2/depth3/’ ;
?php
// Для создания вложенной структуры необходимо указать параметр
// $recursive в mkdir().
if (! mkdir ( $structure , 0777 , true )) die( ‘Не удалось создать директории. ‘ );
>
Смотрите также
- is_dir() — Определяет, является ли имя файла директорией
- rmdir() — Удаляет директорию
- umask() — Изменяет текущую umask
User Contributed Notes 5 notes
When using the recursive parameter bear in mind that if you’re using chmod() after mkdir() to set the mode without it being modified by the value of uchar() you need to call chmod() on all created directories. ie:
mkdir ( ‘/test1/test2’ , 0777 , true );
chmod ( ‘/test1/test2’ , 0777 );
?>
May result in «/test1/test2» having a mode of 0777 but «/test1» still having a mode of 0755 from the mkdir() call. You’d need to do:
mkdir ( ‘/test1/test2’ , 0777 , true );
chmod ( ‘/test1’ , 0777 );
chmod ( ‘/test1/test2’ , 0777 );
?>
This is an annotation from Stig Bakken:
The mode on your directory is affected by your current umask. It will end
up having ( and (not )). If you want to create one
that is publicly readable, do something like this:
$oldumask = umask ( 0 );
mkdir ( ‘mydir’ , 0777 ); // or even 01777 so you get the sticky bit set
umask ( $oldumask );
?>
mkdir, file rw, permission related notes for Fedora 3////
If you are using Fedora 3 and are facing permission problems, better check if SElinux is enabled on ur system. It add an additional layer of security and as a result PHP cant write to the folder eventhough it has 777 permissions. It took me almost a week to deal with this!
If you are not sure google for SElinux or ‘disabling SELinux’ and it may be the cure! Best of luck!
Remember to use clearstatcache()
. when working with filesystem functions.
Otherwise, as an example, you can get an error creating a folder (using mkdir) just after deleting it (using rmdir).
When creating a file using mkdir() the default root will be the DocumentRoot (in XAMPP) itself.
If you use mkdir(«myfile») in something.php, instead of creating the folder in includes, php will create it in the project folder
Создание, назначение доступа, удаление и проверка наличия папки в PHP
Для создания папки применяется функция mkdir. Обязательным параметром для этой функции является pathname, где задается путь к создаваемой директории.
При таком указании папки, она будет создана в той же директории, из которой был запущен php-скрипт. Если нужно создать каталог в другом месте, можно задать относительный путь к создаваемой папке или указать полный путь от корневой директории сайта.
mkdir("../newfolder"); // на уровень ниже
mkdir("/folder1/folder2/newfolder"); // полный путь
В последнем примере обязательным условием будет существование подкаталогов «folder1» и «folder2». Если их не будет, функция, в таком виде не сможет выполнить создание папки и вернет ошибку:
Warning: mkdir() [function.mkdir]: No such file or directory in …
В случае удачного выполнения, функция возвращает значение True. Если пака не была создана, возвращается значение False.
if (mkdir("newfolder"))
echo "Папка успешно создана";
else
echo "Папка не создана";
Но не стоит использовать эту функцию без проверки на наличие папки, так как ошибку о том, что не удалось создать папку, сервер все равно будет выводить.
Назначение прав при создании папки
За назначение прав на создаваемую папку отвечает второй необязательный параметр функции mkdir. По умолчанию, назначаются максимальные привилегии – 0777.
Права назначаются восьмеричным значением с обязательным нулем на первом месте. Не считая первого нуля, числа означают уровни доступа для владельца, для группы владельца, для всех остальных.
Чаще всего права задаются составной суммой, например:
5 – чтение и выполнение (1+4).
mkdir("newfolder", 0777); // полный доступ для всех
Создание нескольких вложенных поддиректорий
Создать несколько вложенных папок сразу можно, просто задав еще один необязательный логический параметр – recursive.
mkdir("folder1/folder2/newfolder", 0777, True); // полный доступ для всех
В этом случае, если папок «folder1» и «folder2» нет, функция создаст и их, и папку «newfolder». Сообщений об ошибках, если других проблем не возникнет, выведено не будет и функция вернет значение True.
Удаление папки
Пустую папку в PHP можно удалить функцией rmdir. В параметре dirname для нее так же задается полный или относительный путь к удаляемому каталогу:
rmdir("folder1/folder2/myfolder");
В каждом из указанных случаев удаляется только папка «myfolder». Если папки нет или путь задан некорректно, будет выведена ошибка:
Warning: rmdir(myfolder) [function.rmdir]: No such file or directory in …
Удаление непустой папки
Удаления непустого каталога выполняется путем последовательного удаления вложенных файлов в папке функцией unlink, а затем удаление пустой папки функцией rmdir. Для этого можно использовать подобную функцию:
function my_delete_dir($mypath) $dir = opendir($mypath);
while (($file = readdir($dir)))
if (is_file($mypath."/".$file))
unlink ($mypath."/".$file);
elseif (is_dir($mypath."/".$file) && ($file != ".") && ($file != ".."))
my_delete_dir ($mypath."/".$file);
>
closedir ($dir);
rmdir ($mypath);
>
my_delete_dir("myfolder"); // вызов функции
Проверка существования каталога
Перед большинством операций с каталогами стоит проверять, существуют ли они. Для этого применяется функция file_exists.
Помимо этого нужно убедиться, что указанный объект именно папка, а не файл — функция is_dir. Проверяемая папка задается относительным или полным путем.
if (file_exists("myfolder"))
echo "Указанная папка существует";
else
echo "Указанной папки нет";
if (is_dir("myfolder"))
echo "Указанный объект папка";
else
echo "Указанный объект не папка";