<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/ref.outcontrol.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'function.ob-start.php',
    1 => 'ob_start',
    2 => '出力のバッファリングを有効にする',
  ),
  'up' => 
  array (
    0 => 'ref.outcontrol.php',
    1 => '出力制御 関数',
  ),
  'prev' => 
  array (
    0 => 'function.ob-list-handlers.php',
    1 => 'ob_list_handlers',
  ),
  'next' => 
  array (
    0 => 'function.output-add-rewrite-var.php',
    1 => 'output_add_rewrite_var',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'reference/outcontrol/functions/ob-start.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="function.ob-start" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">ob_start</h1>
  <p class="verinfo">(PHP 4, PHP 5, PHP 7, PHP 8)</p><p class="refpurpose"><span class="refname">ob_start</span> &mdash; <span class="dc-title">出力のバッファリングを有効にする</span></p>

 </div>
 
 <div class="refsect1 description" id="refsect1-function.ob-start-description">
  <h3 class="title">説明</h3>
  <div class="methodsynopsis dc-description">
   <span class="methodname"><strong>ob_start</strong></span>(<span class="methodparam"><span class="type"><span class="type"><a href="language.types.null.php" class="type null">?</a></span><span class="type"><a href="language.types.callable.php" class="type callable">callable</a></span></span> <code class="parameter">$callback</code><span class="initializer"> = <strong><code><a href="reserved.constants.php#constant.null">null</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">$chunk_size</code><span class="initializer"> = 0</span></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$flags</code><span class="initializer"> = <strong><code><a href="outcontrol.constants.php#constant.php-output-handler-stdflags">PHP_OUTPUT_HANDLER_STDFLAGS</a></code></strong></span></span>): <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span></div>

  <p class="para rdfs-comment">
   この関数は出力のバッファリングをオンにします。
   出力のバッファリングを有効にすると、
   (ヘッダ以外の) スクリプトからの出力は実際には行われず、
   代わりに内部バッファに保存されます。
  </p>
  <p class="para">
   この内部バッファの内容は、<span class="function"><a href="function.ob-get-contents.php" class="function">ob_get_contents()</a></span>
   を用いて文字列変数にコピーされます。
   内部バッファの内容を出力するには
   <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span> を使用します。
   <span class="function"><a href="function.ob-end-clean.php" class="function">ob_end_clean()</a></span>
   は、バッファの内容を出力せずに消去します。
  </p>
  <div class="warning"><strong class="warning">警告</strong>
   <p class="para">
    web サーバーによっては (例: Apache)、コールバック関数からコールされた際に、
    スクリプトの実行ディレクトリを変更するものがあります。
    コールバック関数の内部で <code class="literal">chdir(dirname($_SERVER[&#039;SCRIPT_FILENAME&#039;]))</code>
    などと指定することで、これをもとに戻すことが可能です。
   </p>
  </div>
  <p class="para">
   出力バッファはスタッカブルであり、このため、他の
   <span class="function"><strong>ob_start()</strong></span> がアクティブの間に
   <span class="function"><strong>ob_start()</strong></span> をコールすることが可能です。この場合、
   <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span> を適切な回数コールするようにしてください。
   複数の出力コールバック関数がアクティブの場合、
   ネストした順番で逐次連続的に出力がフィルタ処理されます。
  </p>
  <p class="para">
   スクリプトが終了した際に、
   出力バッファリングがまだアクティブな場合、
   PHP はバッファリングされた内容を自動的に出力します。
  </p>
 </div>


 <div class="refsect1 parameters" id="refsect1-function.ob-start-parameters">
  <h3 class="title">パラメータ</h3>
  <p class="para">
   <dl>
    
     <dt><code class="parameter">callback</code></dt>
     <dd>
      <p class="para">
       オプションの引数 <code class="parameter">callback</code>
       関数を指定することが可能です。この関数は、パラメータとして文字列をとり、
       文字列を返します。このコールバック関数は、
       出力バッファがフラッシュ (送信) あるいは消去
       (<span class="function"><a href="function.ob-flush.php" class="function">ob_flush()</a></span>, <span class="function"><a href="function.ob-clean.php" class="function">ob_clean()</a></span>
       あるいは同等の関数で) された場合、
       またはリクエストの最後にブラウザに出力をフラッシュする際にコールされます。
       <code class="parameter">callback</code> がコールされた際に、
       この関数は出力バッファの内容をパラメータとして受け取ります。このコールバック関数は、
       新規の出力バッファを実際に出力される結果として返す必要があり、
       この結果はブラウザに送信されます。
       <code class="parameter">callback</code> がコール可能な関数ではない場合は
       <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> を返します。
       コールバックのシグネチャは、次のとおりです。
      </p>
      <p class="para">
       <div class="methodsynopsis dc-description">
        <span class="methodname"><span class="replaceable">handler</span></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$buffer</code></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$phase</code><span class="initializer"> = ?</span></span>): <span class="type"><a href="language.types.string.php" class="type string">string</a></span></div>

       <dl>
        
         <dt><code class="parameter">buffer</code></dt>
         <dd>
          <span class="simpara">
           出力バッファの内容。
          </span>
         </dd>
        
        
         <dt><code class="parameter">phase</code></dt>
         <dd>
          <span class="simpara">
           <a href="outcontrol.constants.php" class="link"><strong><code>PHP_OUTPUT_HANDLER_*</code></strong>
           定数</a> のビットマスク
          </span>
         </dd>
        
       </dl>
      </p>
      <p class="para">
       <code class="parameter">callback</code> が <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>
       を返すと、元の入力がそのままブラウザに送信されます。
      </p>
      <p class="para">
       <code class="parameter">callback</code> パラメータに <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> 値を渡すと、
       これをバイパスすることができます。
      </p>
      <p class="para">
       <span class="function"><a href="function.ob-end-clean.php" class="function">ob_end_clean()</a></span>、
       <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span>、<span class="function"><a href="function.ob-clean.php" class="function">ob_clean()</a></span>、
       <span class="function"><a href="function.ob-flush.php" class="function">ob_flush()</a></span> および <span class="function"><strong>ob_start()</strong></span>
       をコールバック関数の内部からコールすることはできません。
       実際にコールした際の挙動は未定義です。バッファの内容を消去したい際には、
       コールバック関数から &quot;&quot; (空文字列) を返してください。
       同じく、<code class="literal">print_r($expression, true)</code> や
       <code class="literal">highlight_file($filename, true)</code> のような
       出力バッファリング関数も、
       コールバック関数の内部からコールすることはできません。
      </p>
      <blockquote class="note"><p><strong class="note">注意</strong>: 
       <p class="para">
        Web ページの圧縮をサポートする圧縮 gz エンコード
        されたデータの Web ブラウザへの送信を容易にするために
        <span class="function"><a href="function.ob-gzhandler.php" class="function">ob_gzhandler()</a></span> が存在します。
        <span class="function"><a href="function.ob-gzhandler.php" class="function">ob_gzhandler()</a></span> は、ブラウザが受け入れる content
        encoding の型を調べ、それに基づいて出力を返します。
       </p>
      </p></blockquote>
     </dd>
    
    
     <dt><code class="parameter">chunk_size</code></dt>
     <dd>
      <p class="para">
       オプションのパラメータ <code class="parameter">chunk_size</code> が渡された場合、
       バッファの長さが <code class="parameter">chunk_size</code> バイトを超えるたびに、
       出力の後でバッファがフラッシュされます。
       デフォルト値は <code class="literal">0</code> で、これは出力関数がコールされるのが
       出力バッファが閉じたときだけであることを意味します。
      </p>
     </dd>
    
    
     <dt><code class="parameter">flags</code></dt>
     <dd>
      <p class="para">
      <code class="parameter">flags</code> はビットマスクで、出力バッファ上でどんな操作ができるのかを制御します。
       デフォルトでは、出力バッファのクリーン、フラッシュ、削除がすべてできるようになっています。
       これは、
       <a href="outcontrol.constants.php#outcontrol.constants.buffer-control-flags" class="link">
        出力バッファの制御フラグ
       </a> を経由して明示的に設定できます。
       詳細は <a href="outcontrol.operations-on-buffers.php" class="xref">バッファに対して可能な操作</a> 
       を参照ください。
      </p>
      <p class="para">
       各フラグが、次の表のように関数へのアクセスを制御します。
       <table class="doctable informaltable">
        
         <thead>
          <tr>
           <th>定数</th>
           <th>関数</th>
          </tr>

         </thead>

         <tbody class="tbody">
          <tr>
           <td><strong><code><a href="outcontrol.constants.php#constant.php-output-handler-cleanable">PHP_OUTPUT_HANDLER_CLEANABLE</a></code></strong></td>
           <td>
            <span class="function"><a href="function.ob-clean.php" class="function">ob_clean()</a></span>
           </td>
          </tr>

          <tr>
           <td><strong><code><a href="outcontrol.constants.php#constant.php-output-handler-flushable">PHP_OUTPUT_HANDLER_FLUSHABLE</a></code></strong></td>
           <td>
            <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span>
            <span class="function"><a href="function.ob-flush.php" class="function">ob_flush()</a></span>
           </td>
          </tr>

          <tr>
           <td><strong><code><a href="outcontrol.constants.php#constant.php-output-handler-removable">PHP_OUTPUT_HANDLER_REMOVABLE</a></code></strong></td>
           <td>
            <span class="function"><a href="function.ob-end-clean.php" class="function">ob_end_clean()</a></span>,
            <span class="function"><a href="function.ob-end-flush.php" class="function">ob_end_flush()</a></span>,
            <span class="function"><a href="function.ob-get-clean.php" class="function">ob_get_clean()</a></span>,
            <span class="function"><a href="function.ob-get-flush.php" class="function">ob_get_flush()</a></span>
           </td>
          </tr>

         </tbody>
        
       </table>

       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <span class="simpara">
         PHP 8.4.0 より前のバージョンでは、flags パラメータに
         <a href="outcontrol.constants.php#outcontrol.constants.flags-returned-by-handler" class="link">出力ハンドラのステータスフラグ</a> も指定可能でした。
        </span>
       </p></blockquote>
      </p>
     </dd>
    
   </dl>
  </p>
 </div>


 <div class="refsect1 returnvalues" id="refsect1-function.ob-start-returnvalues">
  <h3 class="title">戻り値</h3>
  <p class="para">
   成功した場合に <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> を、失敗した場合に <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> を返します。
  </p>
 </div>


 <div class="refsect1 examples" id="refsect1-function.ob-start-examples">
  <h3 class="title">例</h3>
  <p class="para">
   <div class="example" id="example-1">
    <p><strong>例1 ユーザー定義のコールバック関数の例</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br /></span><span style="color: #007700">function </span><span style="color: #0000BB">callback</span><span style="color: #007700">(</span><span style="color: #0000BB">$buffer</span><span style="color: #007700">)<br />{<br />  </span><span style="color: #FF8000">// apples を全て oranges に置換する<br />  </span><span style="color: #007700">return (</span><span style="color: #0000BB">str_replace</span><span style="color: #007700">(</span><span style="color: #DD0000">"apples"</span><span style="color: #007700">, </span><span style="color: #DD0000">"oranges"</span><span style="color: #007700">, </span><span style="color: #0000BB">$buffer</span><span style="color: #007700">));<br />}<br /><br /></span><span style="color: #0000BB">ob_start</span><span style="color: #007700">(</span><span style="color: #DD0000">"callback"</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;<br /></span>&lt;html&gt;<br />&lt;body&gt;<br />&lt;p&gt;It's like comparing apples to oranges.&lt;/p&gt;<br />&lt;/body&gt;<br />&lt;/html&gt;<br /><span style="color: #0000BB">&lt;?php<br /><br />ob_end_flush</span><span style="color: #007700">();<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>上の例の出力は以下となります。</p></div>
    <div class="example-contents screen">
<div class="examplescode"><pre class="examplescode">&lt;html&gt;
&lt;body&gt;
&lt;p&gt;It&#039;s like comparing oranges to oranges.&lt;/p&gt;
&lt;/body&gt;
&lt;/html&gt;</pre>
</div>
    </div>
   </div>
  </p>

  <p class="para">
   <div class="example" id="function.ob-start.flags-bc">
    <p><strong>例2 削除不可能な出力バッファを作る例</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />ob_start</span><span style="color: #007700">(</span><span style="color: #0000BB">null</span><span style="color: #007700">, </span><span style="color: #0000BB">0</span><span style="color: #007700">, </span><span style="color: #0000BB">PHP_OUTPUT_HANDLER_STDFLAGS </span><span style="color: #007700">^ </span><span style="color: #0000BB">PHP_OUTPUT_HANDLER_REMOVABLE</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

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


 <div class="refsect1 seealso" id="refsect1-function.ob-start-seealso">
  <h3 class="title">参考</h3>
  <p class="para">
   <ul class="simplelist">
    <li><span class="function"><a href="function.ob-get-contents.php" class="function" rel="rdfs-seeAlso">ob_get_contents()</a> - 出力用バッファの内容を返す</span></li>
    <li><span class="function"><a href="function.ob-end-clean.php" class="function" rel="rdfs-seeAlso">ob_end_clean()</a> - アクティブな出力用バッファをクリア(消去)し、出力のバッファリングをオフにする</span></li>
    <li><span class="function"><a href="function.ob-end-flush.php" class="function" rel="rdfs-seeAlso">ob_end_flush()</a> - アクティブな出力用バッファをフラッシュ(送信)し、アクティブな出力バッファをオフにする</span></li>
    <li><span class="function"><a href="function.ob-implicit-flush.php" class="function" rel="rdfs-seeAlso">ob_implicit_flush()</a> - 自動フラッシュをオンまたはオフにする</span></li>
    <li><span class="function"><a href="function.ob-gzhandler.php" class="function" rel="rdfs-seeAlso">ob_gzhandler()</a> - 出力バッファを gzip 圧縮するための ob_start コールバック関数</span></li>
    <li><span class="function"><a href="function.ob-iconv-handler.php" class="function" rel="rdfs-seeAlso">ob_iconv_handler()</a> - 出力バッファハンドラとして文字エンコーディングを変換する</span></li>
    <li><span class="function"><a href="function.mb-output-handler.php" class="function" rel="rdfs-seeAlso">mb_output_handler()</a> - 出力バッファ内で文字エンコーディングを変換するコールバック関数</span></li>
    <li><span class="function"><a href="function.ob-tidyhandler.php" class="function" rel="rdfs-seeAlso">ob_tidyhandler()</a> - バッファを修正するための ob_start コールバック関数</span></li>
   </ul>
  </p>
 </div>
  

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