Основы PHP
  Что такое PHP?
  Возможности PHP
  Преимущества PHP
  История развития
  Что нового в PHP5?
  «Движок» PHP
  Переход на PHP 5.3
New Переход на PHP 5.6
  Введение в PHP
  Изучение PHP
  Основы CGI
  Синтаксис PHP
  Типы данных PHP
  Переменные в PHP
  Константы PHP
  Выражения PHP
  Операторы PHP
  Конструкции PHP
  Ссылки в PHP
  PHP и ООП
  Безопасность
  Функции PHP
  Функции по категориям
  Функции по алфавиту
  Стандартные функции
  Пользовательские
  PHP и HTTP
  Работа с формами
  PHP и Upload
  PHP и Cookies
  PHP и базы данных
  PHP и MySQL
  Документация MySQL
  Учебники
  Учебники по PHP
  Учебники по MySQL
  Другие учебники
  Уроки PHP
  Введение
  Самые основы
  Управление
  Функции
  Документация
  Математика
  Файлы
  Основы SQL
  Дата и время
  CURL
  Изображения
  Стили
  Безопасность
  Установка
  Проектирование БД
  Регулярные выражения
  Подготовка к работе
  Быстрый старт
  Установка PHP
  Установка MySQL
  Конфигурация PHP
  Download / Скачать
  Скачать Apache
  Скачать PHP
  Скачать PECL
  Скачать PEAR
  Скачать MySQL
  Редакторы PHP
  Полезные утилиты
  Документация
  PHP скрипты
  Скачать скрипты
  Инструменты
  PHP в примерах
  Новости портала
 Главная   »  Функции PHP
 
 

Функции управления выводом

Введение

Функции управления выводом позволяют определять, когда вывод будет отправлен из скрипта. Это можно использовать в различных ситуациях, особенно если вам нужно выслать шапки/headers браузеру, после того как ваш скрипт начал выводить данные. Функции управления выводом не влияют на шапки, высылаемые функциями header() или setcookie(), только на такие функции, как echo(), и на данные между блоками PHP-кода.

Требования

Эти функции всегда доступны.

Установка

Для использования этих функций не требуется проведение установки, поскольку они являются частью ядра PHP.

Настройка во время выполнения

Поведение этих функций зависит от установок в php.ini.

Таблица 1. Директивы функций управления выводом

Имя директивы Значение по умолчанию Примечания
output_buffering "0"  
output_handler NULL Доступна с PHP 4.0.4.
implicit_flush "0"  

Краткое разъяснение конфигурационных директив.

output_buffering boolean/integer

Вы можете включить буферизацию вывода для всех файлов, устанавливая эту директиву в 'ON'. Если Вы желаете ограничить размер буфера к некоторому размеру - вы можете использовать максимальное число байт вместо 'ON', как значение для этой директивы (например, output_buffering=4096). С PHP 4.3.5, эта директива всегда выключена в PHP-CLI.

output_handler string

Вы можете переадресовать весь вывод ваших сценариев к HTML. Например, если вы устанавливаете output_handler в mb_output_handler(), кодировка будет, очевидно, преобразована в указанную кодировку. Установка любого обработчика вывода автоматически включает буферизацию вывода.

Примечание: Вы не можете использовать совместно mb_output_handler() с ob_iconv_handler() и вы не можете использовать совместно ob_gzhandler() и zlib.output_compression.

Примечание: Только встроенные функции могут использоваться с этой директивой. Для определяемых пользователем функций (пользовательских функций), используйте ob_start().

implicit_flush boolean

FALSE по умолчанию. Изменения параметра в TRUE предписывает слою вывода PHP сбрасывать на диск себя автоматически после каждого блока вывода. Это эквивалентно запросу функции PHP flush() после каждого запроса print() или echo() и каждого блока HTML.

При использовании PHP в пределах среды сети, включение этой опции влечет за собой уменьшение производительности, и вообще данная опция рекомендуется только для отладки. Эти значения по умолчанию - TRUE при работе под CLI SAPI.

See also ob_implicit_flush().

Типы ресурсов

Данное расширение не определяет никакие типы ресурсов.

Предопределенные константы

Данное расширение не определяет никакие константы.

Примеры


Пример 1. Пример управления выводом

<?php

ob_start
();
echo 
"Hello\n";

setcookie("cookiename""cookiedata");

ob_end_flush();

?>

В приведённом примере вывод из echo() будет сохранён в буфере вывода, пока ob_end_flush() не будет вызвана. Тем временем вызов setcookie() успешно сохранил cookie без возникновения ошибки. (Вы не можете нормально отправить заголовки браузеру, после того как данные уже были отправлены.)

Примечание: При апгрейде с PHP 4.1 (and 4.2) на 4.3 из-за ошибки вы должны устанавливать implict_flush в OFF в вашем php.ini, иначе функция ob_start() не будет работать правильно.

Смотрите также

Смотрите также header() и setcookie().

Содержание

flush -- Освобождает (выводит) буфер вывода
ob_clean --  Очищает буфер вывода
ob_end_clean --  Очищает буфер вывода и выключает буферизацию вывода
ob_end_flush -- Освобождает (выводит) буфер вывода и выключает буферизацию вывода
ob_flush -- Освобождает (выводит) буфер вывода
ob_get_clean --  Получает текущее содержимое буфера, и очищает текущий буфер вывода
ob_get_contents --  Возвращает содержимое буфера вывода
ob_get_flush --  Освобождает буфер выводаr, возвращает его как строку и выключает буферизацию вывода
ob_get_length --  Возвращает длину буфера вывода
ob_get_level --  Возвращает уровень вложенности вывода буферизующего механизма
ob_get_status --  Получает статус буферов вывода
ob_gzhandler --  Функция обратного вызова ob_start gzip буфера вывода
ob_implicit_flush --  Включает или отключает неявный сброс буфера вывода
ob_list_handlers --  Перечисляет все используемые обработчики вывода
ob_start -- Включает буферизацию вывода
output_add_rewrite_var --  Перезаписывает значения URL
output_reset_rewrite_vars --  Сбрасывает перезаписываемые значения URL
 
 
 Функции по алфавиту 
   Содержание   
 Функции по категориям 
Есть еще вопросы или что-то непонятно - добро пожаловать на наш  форум портала PHP.SU 
 

 
Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS