stream_wrapper_register
(PHP 4 >= 4.3.2, PHP 5, PHP 7)
stream_wrapper_register — Регистрирует обёртку URL, реализованную в виде PHP-класса
Описание
$protocol
, string $class
, int $flags
= 0
) : boolПозволяет вам реализовать ваши собственные обработчики протоколов и потоков для использования со всеми другими функциями файловой системы (такими как fopen(), fread() и т.д.).
Список параметров
-
protocol
-
Название регистрируемой обёртки.
-
class
-
Название класса, который реализует протокол
protocol
. -
flags
-
Должно быть установлено в
STREAM_IS_URL
, если параметрprotocol
является протоколом URL. По умолчанию 0, локальный поток.
Возвращаемые значения
Возвращает true
в случае успешного завершения или false
в случае возникновения ошибки.
stream_wrapper_register() будет возвращать false
, если
протокол protocol
уже имеет обработчик.
Примеры
Пример #1 Как зарегистрировать обёртку потока
<?php
$existed = in_array("var", stream_get_wrappers());
if ($existed) {
stream_wrapper_unregister("var");
}
stream_wrapper_register("var", "VariableStream");
$myvar = "";
$fp = fopen("var://myvar", "r+");
fwrite($fp, "line1\n");
fwrite($fp, "line2\n");
fwrite($fp, "line3\n");
rewind($fp);
while (!feof($fp)) {
echo fgets($fp);
}
fclose($fp);
var_dump($myvar);
if ($existed) {
stream_wrapper_restore("var");
}
?>
Результат выполнения данного примера:
line1 line2 line3 string(18) "line1 line2 line3 "
Смотрите также
- Класс-прототип streamWrapper
- Пример класса, зарегистрированного в качестве обертки потока
- stream_wrapper_unregister() - Отменяет регистрацию обёртки URL
- stream_wrapper_restore() - Восстанавливает отменённую ранее встроенную обёртку
- stream_get_wrappers() - Получить список зарегистрированных потоков