file_get_contents
(PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)
file_get_contents — Читает содержимое файла в строку
Описание
Использование функции file_get_contents()
наиболее предпочтительно в случае необходимости получить
содержимое файла целиком, поскольку для улучшения производительности
функция использует технику отображения файла в память
(memory mapping), если она поддерживается вашей операционной системой.
Замечание:
Если вы открываете URI, содержащий спецсимволы, такие как пробел,
вам нужно закодировать URI при помощи urlencode().
Список параметров
-
filename
-
Имя читаемого файла.
-
use_include_path
-
Замечание:
Можно использовать константу
FILE_USE_INCLUDE_PATH
для поиска файла
в include path.
Только помните, что если вы используете строгую типизацию,
то так сделать не получится, поскольку
FILE_USE_INCLUDE_PATH
имеет тип int.
В таком случае используйте true
.
-
context
-
Корректный ресурс контекста, созданный с помощью функции
stream_context_create(). Если в использовании
особого контекста нет необходимости, можно пропустить этот параметр
передав в него значение null
.
-
offset
-
Смещение, с которого начнётся чтение оригинального потока.
Отрицательное значение смещения будет отсчитываться с конца потока.
Поиск смещения (offset
) не поддерживается при
работе с удалёнными файлами. Попытка поиска смещения на нелокальных
файлах может работать при небольших смещениях, но результат будет
непредсказуемым, так как функция работает на буферизованном потоке.
-
length
-
Максимальный размер читаемых данных. По умолчанию чтение
осуществляется пока не будет достигнут конец файла. Учтите, что
этот параметр применяется и к потоку с фильтрами.
Возвращаемые значения
Функция возвращает прочтённые данные или false
в случае возникновения ошибки.
ВниманиеФункция
возвращает как логическое значение false
,
так и нелогическое значение, которое приводится к false
.
Прочитайте раздел
«Логический тип»,
чтобы получить дополнительную информацию.
Используйте оператор ===
для проверки значения, которое возвращает функция.
Ошибки
Будет сгенерирована ошибка уровня E_WARNING
в случаях,
если не удастся найти filename
, задан length
меньше нуля, или поиск по смещению offset
в потоке
завершится неудачно.
Когда file_get_contents() вызывается в каталоге,
в Windows ошибка генерируется E_WARNING
,
а с PHP 7.4 также в других операционных системах.
Примеры
Пример #1 Получить и вывести исходный код домашней страницы сайта
<?php
$homepage = file_get_contents('http://www.example.com/');
echo $homepage;
?>
Пример #2 Поиск файлов в include_path
<?php
// Если включены строгие типы, то есть объявлено (strict_types=1);
$file = file_get_contents('./people.txt', true);
// Иначе
$file = file_get_contents('./people.txt', FILE_USE_INCLUDE_PATH);
?>
Пример #3 Чтение секции файла
<?php
// Читаем 14 символов, начиная с 21 символа
$section = file_get_contents('./people.txt', FALSE, NULL, 20, 14);
var_dump($section);
?>
Вывод приведённого примера будет похож на:
string(14) "lle Bjori Ro"
Пример #4 Использование потоковых контекстов
<?php
// Создаём поток
$opts = array(
'http'=>array(
'method'=>"GET",
'header'=>"Accept-language: en\r\n" .
"Cookie: foo=bar\r\n"
)
);
$context = stream_context_create($opts);
// Открываем файл с помощью установленных выше HTTP-заголовков
$file = file_get_contents('http://www.example.com/', false, $context);
?>
Примечания
Замечание: Эта функция
безопасна для обработки данных в двоичной форме.
ПодсказкаВ эту функцию в качестве имени файла
можно передавать URL-адреса, если была включена директива fopen wrappers.
Подробнее о том, как указать имя файла, рассказано в описании функции fopen().
В разделе «Поддерживаемые протоколы и обёртки» также даны ссылки на информацию о способностях поддерживаемых обёрток,
замечания по работе с ними и список
предопределённых переменных, которые они дают.
ВниманиеПри использовании SSL,
Microsoft IIS нарушает протокол, закрывая соединение без отправки индикатора close_notify
.
PHP сообщит об этом как «SSL: Fatal Protocol Error» в тот момент, когда будет достигнут конца данных.
Чтобы обойти это, нужно установить директиву error_reporting на уровень,
исключающий E_WARNING. PHP умеет определять, что на стороне сервера проблемный IIS
при открытии потока обёрткой https://
и не выводит предупреждение.
Если разработчик создаёт сокет ssl://
через вызов функции fsockopen(),
он сам отвечает за определение и подавление этого предупреждения.