<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/features.commandline.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'features.commandline.webserver.php',
    1 => 'ビルトインウェブサーバー',
    2 => 'ビルトインウェブサーバー',
  ),
  'up' => 
  array (
    0 => 'features.commandline.php',
    1 => 'コマンドラインの使用法',
  ),
  'prev' => 
  array (
    0 => 'features.commandline.interactive.php',
    1 => '対話シェル',
  ),
  'next' => 
  array (
    0 => 'features.commandline.ini.php',
    1 => 'INI 設定',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'features/commandline.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="features.commandline.webserver" class="section">
  <h2 class="title">ビルトインウェブサーバー</h2>

  <div class="warning"><strong class="warning">警告</strong>
   <p class="para">
    このウェブサーバーは、アプリケーション開発の支援用として設計されたものです。
    テスト用に使ったり、制約のある環境でアプリケーションをデモするために使ったりすることもできるでしょう。
    あらゆる機能を兼ね備えたウェブサーバーを目指したものではないので、
    公開ネットワーク上で使ってはいけません。
   </p>
  </div>

  <p class="para">
   <abbr title="Command Line Interpreter/Interface">CLI</abbr> <abbr title="Server Application Programming Interface">SAPI</abbr> にはウェブサーバーの機能が組み込まれています。
  </p>

  <p class="para">
   このウェブサーバーは単一のシングルスレッドプロセスしか実行しないので、
   リクエストがブロックされると、PHP アプリケーションはストールします。
  </p>

  <p class="para">
    URI リクエストの処理は、PHP を開始した時点の作業ディレクトリから行われます。
    -t オプションを使えば、ドキュメントルートを明示的に指定することができます。
    URI リクエストにファイルが含まれない場合は、指定したディレクトリにある index.php
    あるいは index.html を返します。どちらも存在しない場合は、
    親ディレクトリにさかのぼって index.php と index.html を探します。
    どちらか一方が見つかるか、あるいはドキュメントルートに達するまでこれが続きます。
    index.php あるいは index.html が見つかるとそれを返し、
    $_SERVER[&#039;PATH_INFO&#039;] が URI の末尾にセットされます。
    見つからなかった場合はレスポンスコード 404 を返します。
  </p>

  <p class="para">
    ウェブサーバーの開始時にコマンドラインで PHP ファイルを指定すると、
    そのファイルをウェブサーバーの &quot;ルーター&quot; スクリプトとして使います。
    このスクリプトは、各 HTTP リクエストの開始時に動きます。このスクリプトが
    <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> を返すと、リクエストされたリソースをそのままの形式で返します。
    それ以外の場合はスクリプトの出力をブラウザに返します。
  </p>

  <p class="para">
   以下にあげる拡張子のファイルについては、標準の MIME タイプを返します:
   <span class="simplelist"><code class="literal">.3gp</code>, <code class="literal">.apk</code>, <code class="literal">.avi</code>, <code class="literal">.bmp</code>, <code class="literal">.css</code>, <code class="literal">.csv</code>, <code class="literal">.doc</code>, <code class="literal">.docx</code>, <code class="literal">.flac</code>, <code class="literal">.gif</code>, <code class="literal">.gz</code>, <code class="literal">.gzip</code>, <code class="literal">.htm</code>, <code class="literal">.html</code>, <code class="literal">.ics</code>, <code class="literal">.jpe</code>, <code class="literal">.jpeg</code>, <code class="literal">.jpg</code>, <code class="literal">.js</code>, <code class="literal">.kml</code>, <code class="literal">.kmz</code>, <code class="literal">.m4a</code>, <code class="literal">.mov</code>, <code class="literal">.mp3</code>, <code class="literal">.mp4</code>, <code class="literal">.mpeg</code>, <code class="literal">.mpg</code>, <code class="literal">.odp</code>, <code class="literal">.ods</code>, <code class="literal">.odt</code>, <code class="literal">.oga</code>, <code class="literal">.ogg</code>, <code class="literal">.ogv</code>, <code class="literal">.pdf</code>, <code class="literal">.png</code>, <code class="literal">.pps</code>, <code class="literal">.pptx</code>, <code class="literal">.qt</code>, <code class="literal">.svg</code>, <code class="literal">.swf</code>, <code class="literal">.tar</code>, <code class="literal">.text</code>, <code class="literal">.tif</code>, <code class="literal">.txt</code>, <code class="literal">.wav</code>, <code class="literal">.webm</code>, <code class="literal">.wmv</code>, <code class="literal">.xls</code>, <code class="literal">.xlsx</code>, <code class="literal">.xml</code>, <code class="literal">.xsl</code>, <code class="literal">.xsd</code>, <code class="literal">.zip</code></span>
  </p>

  <p class="simpara">
   PHP 7.4.0 以降では、ビルトインウェブサーバーに対して複数のリクエストを並列で投げる必要があるテストコードのために、
   複数のワーカーをフォークさせるよう設定できるようになりました。
   サーバーを起動する前に欲しいワーカーの数を <var class="envar">PHP_CLI_SERVER_WORKERS</var> 環境変数に設定してください。
  </p>
  <blockquote class="note"><p><strong class="note">注意</strong>: 
   <span class="simpara">この機能は Windows ではサポートされていません。</span>
  </p></blockquote>
  <blockquote class="note"><p><strong class="note">注意</strong>: 
   <span class="simpara">
    PHP のコマンドラインの使い方やオプションについては、
    <strong class="command">php --help</strong> または <strong class="command">man php</strong> を実行してください。
    すべてのオプションがウェブサーバーの実行時に適用されるわけではありません。
   </span>
  </p></blockquote>
  <div class="warning"><strong class="warning">警告</strong>
   <p class="para">
    この機能は <em>実験的なもの</em> であり、
    本番環境で使うことを意図した機能では <em>ありません</em>。
    ビルトインウェブサーバーは本番環境で使うものでは<em>ありません</em>。
   </p>
  </div>

  <div class="example" id="example-1">
   <p><strong>例1 ウェブサーバーの起動</strong></p> 
   <div class="example-contents">
<div class="shellcode"><pre class="shellcode">$ cd ~/public_html
$ php -S localhost:8000</pre>
</div>
   </div>

   <div class="example-contents"><p>
     ターミナルには次のように表示されます。
   </p></div>
   <div class="example-contents screen">
<div class="cdata"><pre>
PHP 5.4.0 Development Server started at Thu Jul 21 10:43:28 2011
Listening on localhost:8000
Document root is /home/me/public_html
Press Ctrl-C to quit
</pre></div>
   </div>
   <div class="example-contents"><p>
     http://localhost:8000/ と
     http://localhost:8000/myscript.html をリクエストした後のターミナルの表示は、
     このようになります。
   </p></div>
   <div class="example-contents screen">
<div class="cdata"><pre>
PHP 5.4.0 Development Server started at Thu Jul 21 10:43:28 2011
Listening on localhost:8000
Document root is /home/me/public_html
Press Ctrl-C to quit.
[Thu Jul 21 10:48:48 2011] ::1:39144 GET /favicon.ico - Request read
[Thu Jul 21 10:48:50 2011] ::1:39146 GET / - Request read
[Thu Jul 21 10:48:50 2011] ::1:39147 GET /favicon.ico - Request read
[Thu Jul 21 10:48:52 2011] ::1:39148 GET /myscript.html - Request read
[Thu Jul 21 10:48:52 2011] ::1:39149 GET /favicon.ico - Request read
</pre></div>
   </div>
   <div class="example-contents"><p>
    Windows 環境、かつ PHP 7.4.0 より前のバージョンでは、
    ルーティングを行うスクリプトがシンボリックリンク先の静的なリソースを処理しない限り、
    それらのリソースにアクセスできませんでした。
   </p></div>
  </div>

  <div class="example" id="example-2">
   <p><strong>例2 ドキュメントルートディレクトリを指定した起動</strong></p> 
   <div class="example-contents">
<div class="shellcode"><pre class="shellcode">$ cd ~/public_html
$ php -S localhost:8000 -t foo/</pre>
</div>
   </div>

   <div class="example-contents"><p>
     ターミナルには次のように表示されます。
   </p></div>
   <div class="example-contents screen">
<div class="cdata"><pre>
PHP 5.4.0 Development Server started at Thu Jul 21 10:50:26 2011
Listening on localhost:8000
Document root is /home/me/public_html/foo
Press Ctrl-C to quit
</pre></div>
   </div>
  </div>

  <div class="example" id="example-3">
   <p><strong>例3 ルータースクリプトの使用</strong></p> 
<div class="example-contents"><p>
  この例では、画像ファイルをリクエストすればそのまま表示し、HTML ファイルをリクエストすると &quot;Welcome to PHP&quot; と表示します。
</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">// router.php<br /></span><span style="color: #007700">if (</span><span style="color: #0000BB">preg_match</span><span style="color: #007700">(</span><span style="color: #DD0000">'/\.(?:png|jpg|jpeg|gif)$/'</span><span style="color: #007700">, </span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">"REQUEST_URI"</span><span style="color: #007700">])) {<br />    return </span><span style="color: #0000BB">false</span><span style="color: #007700">;    </span><span style="color: #FF8000">// リクエストされたリソースをそのままの形式で扱います。<br /></span><span style="color: #007700">} else { <br />    echo </span><span style="color: #DD0000">"&lt;p&gt;Welcome to PHP&lt;/p&gt;"</span><span style="color: #007700">;<br />}<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   <div class="example-contents">
<div class="shellcode"><pre class="shellcode">$ php -S localhost:8000 router.php</pre>
</div>
   </div>

  </div>

  <div class="example" id="example-4">
   <p><strong>例4 CLI ウェブサーバーを使っているかどうかのチェック</strong></p> 
<div class="example-contents"><p>
  フレームワークのルータースクリプトを、開発中は CLI ウェブサーバーで使って
  その後は本番環境のウェブサーバーでも使うという例です。
</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">// router.php<br /></span><span style="color: #007700">if (</span><span style="color: #0000BB">php_sapi_name</span><span style="color: #007700">() == </span><span style="color: #DD0000">'cli-server'</span><span style="color: #007700">) {<br />    </span><span style="color: #FF8000">/* 静的コンテンツのルーティングをして false を返します */<br /></span><span style="color: #007700">}<br /></span><span style="color: #FF8000">/* 通常の index.php の処理を続きます */<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

   <div class="example-contents">
<div class="shellcode"><pre class="shellcode">$ php -S localhost:8000 router.php</pre>
</div>
   </div>

  </div>

  <div class="example" id="example-5">
   <p><strong>例5 未サポートのファイル形式の処理</strong></p> 
<div class="example-contents"><p>
  CLI ウェブサーバーで対応していない MIME タイプの静的リソースを扱うには、このようにします。
</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">// router.php<br /></span><span style="color: #0000BB">$path </span><span style="color: #007700">= </span><span style="color: #0000BB">pathinfo</span><span style="color: #007700">(</span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">"SCRIPT_FILENAME"</span><span style="color: #007700">]);<br />if (</span><span style="color: #0000BB">$path</span><span style="color: #007700">[</span><span style="color: #DD0000">"extension"</span><span style="color: #007700">] == </span><span style="color: #DD0000">"el"</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">header</span><span style="color: #007700">(</span><span style="color: #DD0000">"Content-Type: text/x-script.elisp"</span><span style="color: #007700">);<br />    </span><span style="color: #0000BB">readfile</span><span style="color: #007700">(</span><span style="color: #0000BB">$_SERVER</span><span style="color: #007700">[</span><span style="color: #DD0000">"SCRIPT_FILENAME"</span><span style="color: #007700">]);<br />}<br />else {<br />    return </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 class="example-contents">
<div class="shellcode"><pre class="shellcode">$ php -S localhost:8000 router.php</pre>
</div>
   </div>

  </div>

  <div class="example" id="example-6">
   <p><strong>例6 CLI ウェブサーバーへのリモートマシンからのアクセス</strong></p> 
<div class="example-contents"><p>
  ウェブサーバーを、任意のインターフェイスからポート 8000 でアクセスできるようにするには、このようにします。
</p></div>
   <div class="example-contents">
<div class="shellcode"><pre class="shellcode">$ php -S 0.0.0.0:8000</pre>
</div>
   </div>

   <div class="warning"><strong class="warning">警告</strong>
    <p class="para">
      ビルトインウェブサーバーは、公開ネットワークで使うべきではありません。
    </p>
   </div>
  </div>

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