<?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 => 'ja',
  ),
  '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' => 'ja',
    '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> ヘッダを送信するために使用されます。
   <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>
   を参照ください。
  </p>
  <p class="para">
   覚えておいて頂きたいのは、<span class="function"><strong>header()</strong></span> 関数は、
   通常の HTML タグまたは 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 /></span><span style="color: #FF8000">/* これはエラーとなります。この上に出力があることに注目してください。<br /> * それは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 /></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">
       特殊な header コールが 2 種類あります。最初のものは、
       文字列 &quot;<code class="literal">HTTP/</code>&quot;
       から始まる全てのヘッダ (大文字・小文字は区別されません) です。
       このヘッダは、送信する HTTP ステータスコードを示すために使用されます。
       例えば、存在しないファイルへのリクエストを処理するためにある PHP
       スクリプトを使用するよう (<code class="literal">ErrorDocument</code>
       ディレクティブにより) Apache を設定する場合、
       そのスクリプトが正しいステータスコードを返すようにする必要があります。
      </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 /></span><span style="color: #FF8000">// この例は、"HTTP/" から始まる特別な場合を示しています。<br />// これより良い、典型的な使い方として、以下があげられます:<br />// 1. header($_SERVER["SERVER_PROTOCOL"] . " 404 Not Found");<br />//    (HTTP/1.0 を使いながら、httpステータスメッセージを上書きする)<br />// 2. http_response_code(404); (デフォルトのメッセージを使う)<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 /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
        </div>

       </div>
      </p>
      <p class="para">
       2 番目の特別なヘッダは、&quot;Location:&quot;
       ヘッダです。このヘッダがブラウザに返されるだけではなく、
       ブラウザに <code class="literal">REDIRECT</code> (302) ステータスコードを返します
       (<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 />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 /></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 />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 /></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>
     PDF ファイルを生成した場合など、
     それをダウンロードするかの確認ダイアログを表示させたいことがあるでしょう。
     そんな場合は、<a href="https://datatracker.ietf.org/doc/html/rfc2183" class="link external">&raquo;&nbsp;Content-Disposition</a>
     ヘッダを使用してファイル名を指定すると、ブラウザ側でダイアログを表示させることができます。
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<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 /></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 スクリプトはしばしば動的に HTML を生成するため、クライアント
     ブラウザやサーバーおよびクライアントブラウザの間でプロキシがキャッシュを
     行ったりするべきではありません。多くのプロキシとクライアントでは、
     以下のコードにより強制的にキャッシュを無効にできます。
    </p></div>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<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 /></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 クッキーを設定する</strong></p>
    <div class="example-contents"><p>
     <span class="function"><a href="function.setcookie.php" class="function">setcookie()</a></span> は、クッキーを設定する便利な方法を提供します。
     <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>
     たとえば、以下のコードは
     <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 />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 /></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">
    ヘッダにアクセスできたりヘッダを出力したりするのは、
    それに対応した 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> をスクリプトでコールするか
    <var class="filename">php.ini</var> またはサーバー設定ファイルの設定ディレクティブ
    <code class="literal">output_buffering</code> を設定することにより
    行うことが可能です。
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">注意</strong>: 
   <p class="para">
    実際に <span class="function"><strong>header()</strong></span> が最初にコールされたか
    どうかにかかわらず、HTTP ステータスヘッダ行は
    クライアントに対し常に最初に送信されます。
    HTTP ヘッダが既に送信されていない限り、
    <span class="function"><strong>header()</strong></span> をコールすることでステータスは
    常に上書きされます。
   </p>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">注意</strong>: 
   <p class="para">
    最近のクライアントの大半は
    <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> も受け付けますが、
    古いクライアントの中にはスキームとホスト名そして絶対パスを含む絶対 URL しか受け付けないものもあります。
    通常は、相対 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 /></span><span style="color: #FF8000">/* カレントディレクトリの別のページにリダイレクトします */<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 /></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">
    <a href="session.configuration.php#ini.session.use-trans-sid" class="link">session.use_trans_sid</a>
    が有効であったとしても、セッション ID が Location ヘッダとともに
    渡されることはありません。<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> - クッキーを送信する</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> - 以前に設定したHTTPヘッダを削除する</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); ?>