<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/ref.network.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'function.header.php',
    1 => 'header',
    2 => 'Отправляет необработанный HTTP-заголовок',
  ),
  'up' => 
  array (
    0 => 'ref.network.php',
    1 => 'Сетевые функции',
  ),
  'prev' => 
  array (
    0 => 'function.getservbyport.php',
    1 => 'getservbyport',
  ),
  'next' => 
  array (
    0 => 'function.header-register-callback.php',
    1 => 'header_register_callback',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/network/functions/header.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="function.header" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">header</h1>
  <p class="verinfo">(PHP 4, PHP 5, PHP 7, PHP 8)</p><p class="refpurpose"><span class="refname">header</span> &mdash; <span class="dc-title">
   Отправляет необработанный HTTP-заголовок
  </span></p>

 </div>

 <div class="refsect1 description" id="refsect1-function.header-description">
  <h3 class="title">Описание</h3>
  <div class="methodsynopsis dc-description">
   <span class="methodname"><strong>header</strong></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$header</code></span>, <span class="methodparam"><span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span> <code class="parameter">$replace</code><span class="initializer"> = <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong></span></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$response_code</code><span class="initializer"> = 0</span></span>): <span class="type"><a href="language.types.void.php" class="type void">void</a></span></div>

  <p class="para rdfs-comment">
   Функция <span class="function"><strong>header()</strong></span> отправляет <abbr title="Hypertext Transfer Protocol">HTTP</abbr>-заголовок.
   <a href="https://datatracker.ietf.org/doc/html/rfc2616" class="link external">&raquo;&nbsp;Спецификация HTTP/1.1</a>
   подробно описывает <abbr title="Hypertext Transfer Protocol">HTTP</abbr>-заголовки.
  </p>
  <p class="para">
   Помните, функцию <span class="function"><strong>header()</strong></span> вызывают строго до вывода данных:
   до появления в скрипте HTML-разметки, пустых строк вне режима PHP-кода и до вывода данных функциями или языковыми конструкциями PHP.
   Разработчики часто допускают ошибку, когда выражениями <span class="function"><a href="function.include.php" class="function">include</a></span>, <span class="function"><a href="function.require.php" class="function">require</a></span>
   или функциями доступа к файлам включают в текущий код внешнее содержимое
   с пробелами или пустыми строками, которые выводятся до вызова
   функции <span class="function"><strong>header()</strong></span>. Те же проблемы возникают
   при записи в одном файле PHP-кода и HTML-разметки.
   <div class="informalexample">
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000">&lt;html&gt;<br /><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #FF8000">/* Этот пример вызовет ошибку. Обратите внимание<br /> * на HTML-тег вверху, который выведется до вызова функции header() */<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">'Location: http://www.example.com/'</span><span style="color: #007700">);<br />exit;<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>
 </div>


 <div class="refsect1 parameters" id="refsect1-function.header-parameters">
  <h3 class="title">Список параметров</h3>
  <p class="para">
   <dl>
    
     <dt><code class="parameter">header</code></dt>
     <dd>
      <p class="para">
       Строка заголовка.
      </p>
      <p class="para">
       PHP обрабатывает два заголовка частным способом. Первый —
       регистронезависимый заголовок, который начинается со строки &quot;<code class="literal">HTTP/</code>&quot;.
       Этот заголовок определит код HTTP-статуса для ответа. Например, если веб-сервер Apache
       через директиву <code class="literal">ErrorDocument</code>
       сконфигурирован на обработку запросов к несуществующим файлам
       PHP-скриптом, то разработчик, вероятно,
       захочет убедиться, что скрипт генерирует правильный код статуса.
      </p>
      <p class="para">
       <div class="informalexample">
        <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #FF8000">// Пример иллюстрирует передачу заголовка "HTTP/" с жёстоко заданной версией протокола.<br />//<br />// Из альтернативных способов указать правильную версию протокола<br />// в типичных случаях вместо установки версии вручную выбирают следующее:<br />// 1. header($_SERVER["SERVER_PROTOCOL"] . " 404 Not Found");<br />//    Вызов переопределяет сообщение об HTTP-статусе для клиентов, которые всё ещё работают по протоколу HTTP/1.0<br />//<br />// 2. http_response_code(404);<br />//    Вызов установит код ответа, а сервер отправит стандартное сообщение о статусе<br />//    и версию протокола<br /><br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">"HTTP/1.1 404 Not Found"</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
        </div>

       </div>
      </p>
      <p class="para">
       Другой специфичный вид заголовка — &quot;Location:&quot;. Функция не только
       отправляет заголовок в браузер, но и возвращает браузеру 302-й код статуса
       <code class="literal">REDIRECT</code>, если только прежде не установили код статуса
       <code class="literal">201</code> или <code class="literal">3xx</code>.
      </p>
      <p class="para">
       <div class="informalexample">
        <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />header</span><span style="color: #007700">(</span><span style="color: #DD0000">"Location: http://www.example.com/"</span><span style="color: #007700">); </span><span style="color: #FF8000">/* Перенаправление браузера */<br /><br />/* Исключить выполнение кода после перенаправления .*/<br /></span><span style="color: #007700">exit;<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
        </div>

       </div>
      </p>
     </dd>
    
    
     <dt><code class="parameter">replace</code></dt>
     <dd>
      <p class="para">
       Необязательный параметр <code class="parameter">replace</code> определяет,
       заменит ли текущий заголовок предыдущий аналогичный заголовок или требуется добавить второй заголовок того же типа.
       По умолчанию параметр заменит заголовок, но если во втором аргументе передать значение <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>,
       функция принудительно установит серию однотипных заголовков. Например:
      </p>
      <p class="para">
       <div class="informalexample">
        <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />header</span><span style="color: #007700">(</span><span style="color: #DD0000">'WWW-Authenticate: Negotiate'</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">'WWW-Authenticate: NTLM'</span><span style="color: #007700">, </span><span style="color: #0000BB">false</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
        </div>

       </div>
      </p>
     </dd>
    
    
     <dt><code class="parameter">response_code</code></dt>
     <dd>
      <p class="para">
       Принудительно задаёт HTTP-код ответа. Обратите внимание, что параметр
       работает, только если строка <code class="parameter">header</code> не пуста.
      </p>
     </dd>
    
   </dl>
  </p>
 </div>


 <div class="refsect1 returnvalues" id="refsect1-function.header-returnvalues">
  <h3 class="title">Возвращаемые значения</h3>
  <p class="para">
   Функция не возвращает значения после выполнения.
  </p>
 </div>


 <div class="refsect1 errors" id="refsect1-function.header-errors">
  <h3 class="title">Ошибки</h3>
  <p class="para">
   При сбое планирования отправки заголовка функция <span class="function"><strong>header()</strong></span>
   выдаёт ошибку уровня <strong><code><a href="errorfunc.constants.php#constant.e-warning">E_WARNING</a></code></strong>.
  </p>
 </div>


 <div class="refsect1 examples" id="refsect1-function.header-examples">
  <h3 class="title">Примеры</h3>
  <p class="para">
   <div class="example" id="example-1">
    <p><strong>Пример #1 Диалог загрузки</strong></p>
    <div class="example-contents"><p>
     При передаче заголовка <a href="https://datatracker.ietf.org/doc/html/rfc2183" class="link external">&raquo;&nbsp;Content-Disposition</a>
     клиент предложит пользователю сохранить пересылаемые
     данные, например PDF-файл, который сгенерировал север,
     и покажет в браузере диалог сохранения файла с рекомендуемым названием.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #FF8000">// Передача PDF-файла<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">'Content-Type: application/pdf'</span><span style="color: #007700">);<br /><br /></span><span style="color: #FF8000">// Установка названия downloaded.pdf<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">'Content-Disposition: attachment; filename="downloaded.pdf"'</span><span style="color: #007700">);<br /><br /></span><span style="color: #FF8000">// Считывание исходного PDF-файла с названием original.pdf<br /></span><span style="color: #0000BB">readfile</span><span style="color: #007700">(</span><span style="color: #DD0000">'original.pdf'</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>
  <p class="para">
   <div class="example" id="example-2">
    <p><strong>Пример #2 Директивы для работы с кешем</strong></p>
    <div class="example-contents"><p>
     PHP-скрипты часто генерируют динамическое содержание, которое не должен
     кешировать браузер клиента или промежуточный кеш между сервером
     и клиентским браузером. На прокси-серверах и в браузерах иногда принудительно
     отключают кеширование путём передачи следующих заголовков:
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />header</span><span style="color: #007700">(</span><span style="color: #DD0000">"Cache-Control: no-cache, must-revalidate"</span><span style="color: #007700">); </span><span style="color: #FF8000">// HTTP/1.1<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">"Expires: Sat, 26 Jul 1997 05:00:00 GMT"</span><span style="color: #007700">); </span><span style="color: #FF8000">// Дата в прошлом<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>
     <blockquote class="note"><p><strong class="note">Замечание</strong>: 
      <p class="para">
       Иногда браузер не кеширует страницы
       даже без передачи заголовков с запретом кеширования. Пользователям доступны настройки браузера,
       которые изменяют поведение кеширования по умолчанию.
       Заголовки с явным запретом кеширования переопределят пользовательские настройки,
       которые указывают браузеру кешировать вывод скрипта.
      </p>
      <p class="para">
       Кроме того, через функцию <span class="function"><a href="function.session-cache-limiter.php" class="function">session_cache_limiter()</a></span>
       и директиву <code class="literal">session.cache_limiter</code> автоматически
       создают правильные заголовки, которые связаны с кешированием при работе с сессиями.
      </p>
     </p></blockquote>
    </p></div>
   </div>
  </p>
  <p class="para">
   <div class="example" id="example-3">
    <p><strong>Пример #3 Настройка cookie</strong></p>
    <div class="example-contents"><p>
     Функцией <span class="function"><a href="function.setcookie.php" class="function">setcookie()</a></span> удобно устанавливать блоки данных cookies.
     Для установки cookie с атрибутами, которые не поддерживает функция <span class="function"><a href="function.setcookie.php" class="function">setcookie()</a></span>,
     вызывают функцию <span class="function"><strong>header()</strong></span>.
    </p></div>
    <div class="example-contents"><p>
     Следующий код, например, устанавливает cookie
     с атрибутом <code class="literal">Partitioned</code>.
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />header</span><span style="color: #007700">(</span><span style="color: #DD0000">'Set-Cookie: name=value; Secure; Path=/; SameSite=None; Partitioned;'</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

   </div>
  </p>
 </div>


 <div class="refsect1 notes" id="refsect1-function.header-notes">
  <h3 class="title">Примечания</h3>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
<p class="para">
 Заголовки доступны и выводятся, только если PHP работает через SAPI-интерфейс с поддержкой заголовков.
 </p>
</p></blockquote>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
   <p class="para">
    Проблему обходят путём буферизации вывода скрипта. Тогда
    выводимые данные буферизуются на сервере, пока не появится
    явная команда на пересылку данных. Буферизацией управляют вручную
    функциями <span class="function"><a href="function.ob-start.php" class="function">ob_start()</a></span> и <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span>,
    либо через директиву <code class="literal">output_buffering</code> в конфигурационном
    файле <var class="filename">php.ini</var>, или путём настройки конфигурации сервера.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
   <p class="para">
    Строка заголовка с HTTP-статусом отправляется
    клиенту первой, даже если первой вызвали функцию
    <span class="function"><strong>header()</strong></span>. Статус возможно переопределить в любое время
    вызовом функции <span class="function"><strong>header()</strong></span> с новой строкой статуса,
    если HTTP-заголовки ещё не отправлялись.
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
   <p class="para">
    Спецификация протокола HTTP/1.1 требует, чтобы в аргументе
    заголовка <a href="http://tools.ietf.org/html/rfc7231#section-7.1.2" class="link external">&raquo;&nbsp;Location:</a>
    указывали абсолютный <abbr title="Uniform Resource Identifier">URI</abbr>,
    который бы включал схему, имя хоста и абсолютный путь, хотя иногда клиенты
    в состоянии принимать и относительные идентификаторы URI. Абсолютный URI возможно построить
    самому через элементы <var class="varname"><a href="reserved.variables.server.php" class="classname">$_SERVER['HTTP_HOST']</a></var>,
    <var class="varname"><a href="reserved.variables.server.php" class="classname">$_SERVER['PHP_SELF']</a></var> или функцией <span class="function"><a href="function.dirname.php" class="function">dirname()</a></span>:
    <div class="informalexample">
     <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #FF8000">/* Перенаправление браузера на другую страницу в той же директории,<br />которую запросили */<br /></span><span style="color: #0000BB">$host  </span><span style="color: #007700">= </span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">'HTTP_HOST'</span><span style="color: #007700">];<br /></span><span style="color: #0000BB">$uri   </span><span style="color: #007700">= </span><span style="color: #0000BB">rtrim</span><span style="color: #007700">(</span><span style="color: #0000BB">dirname</span><span style="color: #007700">(</span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">'PHP_SELF'</span><span style="color: #007700">]), </span><span style="color: #DD0000">'/\\'</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$extra </span><span style="color: #007700">= </span><span style="color: #DD0000">'mypage.php'</span><span style="color: #007700">;<br /></span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">"Location: http://</span><span style="color: #0000BB">$host$uri</span><span style="color: #DD0000">/</span><span style="color: #0000BB">$extra</span><span style="color: #DD0000">"</span><span style="color: #007700">);<br />exit;<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
     </div>

    </div>
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">Замечание</strong>: 
   <p class="para">
    Идентификатор сессии не передаётся вместе с заголовком Location
    даже при активации настройки <a href="session.configuration.php#ini.session.use-trans-sid" class="link">session.use_trans_sid</a>.
    Идентификатор потребуется передать вручную через константу <strong><code><a href="session.constants.php#constant.sid">SID</a></code></strong>.
   </p>
  </p></blockquote>
 </div>


 <div class="refsect1 seealso" id="refsect1-function.header-seealso">
  <h3 class="title">Смотрите также</h3>
  <p class="para">
   <ul class="simplelist">
    <li><span class="function"><a href="function.headers-sent.php" class="function" rel="rdfs-seeAlso">headers_sent()</a> - Проверяет, были ли отправлены заголовки</span></li>
    <li><span class="function"><a href="function.setcookie.php" class="function" rel="rdfs-seeAlso">setcookie()</a> - Отправляет cookie</span></li>
    <li><span class="function"><a href="function.http-response-code.php" class="function" rel="rdfs-seeAlso">http_response_code()</a> - Получает или устанавливает код ответа HTTP</span></li>
    <li><span class="function"><a href="function.header-remove.php" class="function" rel="rdfs-seeAlso">header_remove()</a> - Удаляет ранее установленные заголовки</span></li>
    <li><span class="function"><a href="function.headers-list.php" class="function" rel="rdfs-seeAlso">headers_list()</a> - Возвращает список переданных заголовков (или готовых к отправке)</span></li>
    <li>
     Раздел документации «<a href="features.http-auth.php" class="link">HTTP-аутентификации</a>»
    </li>
   </ul>
  </p>
 </div>


</div><?php manual_footer($setup); ?>