stream_get_meta_data
(PHP 4 >= 4.3.0, PHP 5, PHP 7)
stream_get_meta_data — Извлекает заголовок/метаданные из потоков/файловых указателей
Описание
$stream
) : array
Получает информацию о существующем потоке stream
.
Список параметров
-
stream
-
Параметр stream может быть любым потоком, созданным при помощи функций fopen(), fsockopen() и pfsockopen().
Возвращаемые значения
Получаемый массив содержит следующие элементы:
-
timed_out
(bool) -true
, если поток превысил время ожидания данных во время последнего вызова функции fread() или fgets(). -
blocked
(bool) -true
, если поток находится в режиме блокирующего ввода-вывода. Смотрите функцию stream_set_blocking(). -
eof
(bool) -true
, если поток достиг конца файла. Заметьте, что для потоков типа socket этот член может быть равенtrue
, даже когдаunread_bytes
не равно нулю. Для того, чтобы определить есть ли ещё данные для чтения, используйте feof() вместо чтения этого элемента. -
unread_bytes
(int) - количество байт, находящихся сейчас в собственном внутреннем буфере PHP.Замечание: Вы не должны использовать это значение в скрипте.
-
stream_type
(string) - метка, описывающая внутреннюю реализацию потока. -
wrapper_type
(string) - метка, описывающая реализацию обёртки протокола, наложенного на поток. Смотрите раздел Поддерживаемые протоколы и обертки для подробной информации об обёртках. -
wrapper_data
(mixed) - специфические для обёртки данные, прикреплённые к этому потоку. Смотрите раздел Поддерживаемые протоколы и обертки для подробной информации об обёртках и их данных. -
mode
(string) - тип доступа, требуемый для этого потока (смотрите таблицу 1 в описании функции fopen()) -
seekable
(bool) - можно ли перемещаться по текущему потоку. -
uri
(string) - URI/имя файла, связанное с этим потоком.
Примеры
Пример #1 Пример использования функцииstream_get_meta_data()
<?php
$url = 'http://www.example.com/';
if (!$fp = fopen($url, 'r')) {
trigger_error("Невозможно открыть URL ($url)", E_USER_ERROR);
}
$meta = stream_get_meta_data($fp);
print_r($meta);
fclose($fp);
?>
Результатом выполнения данного примера будет что-то подобное:
Array ( [wrapper_data] => Array ( [0] => HTTP/1.1 200 OK [1] => Server: Apache/2.2.3 (Red Hat) [2] => Last-Modified: Tue, 15 Nov 2005 13:24:10 GMT [3] => ETag: "b300b4-1b6-4059a80bfd280" [4] => Accept-Ranges: bytes [5] => Content-Type: text/html; charset=UTF-8 [6] => Set-Cookie: FOO=BAR; expires=Fri, 21-Dec-2012 12:00:00 GMT; path=/; domain=.example.com [6] => Connection: close [7] => Date: Fri, 16 Oct 2009 12:00:00 GMT [8] => Age: 1164 [9] => Content-Length: 438 ) [wrapper_type] => http [stream_type] => tcp_socket/ssl [mode] => r [unread_bytes] => 438 [seekable] => [uri] => http://www.example.com/ [timed_out] => [blocked] => 1 [eof] => )
Примечания
Замечание:
Эта функция НЕ будет работать с сокетами, созданными при помощи расширения Socket.
Смотрите также
- get_headers() - Возвращает все заголовки из ответа сервера на HTTP-запрос
- $http_response_header