<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/features.file-upload.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'features.file-upload.multiple.php',
    1 => '複数ファイルのアップロード',
    2 => '複数ファイルのアップロード',
  ),
  'up' => 
  array (
    0 => 'features.file-upload.php',
    1 => 'ファイルアップロードの処理',
  ),
  'prev' => 
  array (
    0 => 'features.file-upload.common-pitfalls.php',
    1 => '陥りやすい落とし穴',
  ),
  'next' => 
  array (
    0 => 'features.file-upload.put-method.php',
    1 => 'PUT メソッドのサポート',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'features/file-upload.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="features.file-upload.multiple" class="sect1">
   <h2 class="title">複数ファイルのアップロード</h2>
   <p class="simpara">
    <code class="literal">input</code> で異なった <code class="literal">name</code> を
    使用することにより、複数のファイルをアップロードすることができます。
   </p>
   <p class="simpara">
    複数のファイルを一度にアップロードし、自動的にまとめられた情報を
    配列で取得することが可能です。これを行うには、HTML フォームで
    複数選択可能なセレクトやチェックボックスを指定する際と同様、
    配列を用いた投稿用の構文を使用する必要があります。
   </p>
   <p class="para">
    <div class="example" id="example-1">
     <p><strong>例1 複数ファイルのアップロード</strong></p>
     <div class="example-contents">
<div class="htmlcode"><pre class="htmlcode">&lt;form action=&quot;file-upload.php&quot; method=&quot;post&quot; enctype=&quot;multipart/form-data&quot;&gt;
  Send these files:&lt;br /&gt;
  &lt;input name=&quot;userfile[]&quot; type=&quot;file&quot; /&gt;&lt;br /&gt;
  &lt;input name=&quot;userfile[]&quot; type=&quot;file&quot; /&gt;&lt;br /&gt;
  &lt;input type=&quot;submit&quot; value=&quot;Send files&quot; /&gt;
&lt;/form&gt;</pre>
</div>
     </div>

    </div>
   </p>
   <p class="simpara">
    上記のフォームで投稿された場合、配列
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']</a></var>,
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['name']</a></var>,
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['size']</a></var>
    が設定されます。
   </p>
   <p class="simpara">
    例えば、ファイル名が <var class="filename">/home/test/review.html</var> 
    および <var class="filename">/home/test/xwp.out</var> のファイルが
    投稿されたとしましょう。この場合、
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['name'][0]</a></var> の値が
    <var class="filename">review.html</var> となり、
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['name'][1]</a></var> の値が
    <var class="filename">xwp.out</var> となります。
    同様に、<var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['size'][0]</a></var> の値が
    <var class="filename">review.html</var> のファイルサイズといったように
    なります。
   </p>
   <p class="simpara">
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['name'][0]</a></var>,
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['tmp_name'][0]</a></var>,
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['size'][0]</a></var>,
    <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES['userfile']['type'][0]</a></var> も設定されます。
   </p>
   <div class="warning"><strong class="warning">警告</strong>
    <p class="simpara">
     <a href="ini.core.php#ini.max-file-uploads" class="link">max_file_uploads</a>
     は一回のリクエストあたりでアップロードできるファイルの数の制限値となります。
     フォームからの一回のリクエストで、
     これを超える数のファイルをアップロードしてしまわないようにしましょう。
    </p>
   </div>
   <p class="para">
    <div class="example" id="example-2">
     <p><strong>例2 ディレクトリ全体をアップロードする</strong></p>
     <div class="example-contents"><p>
      HTML のファイルアップロードフィールド中に、
      <code class="literal">webkitdirectory</code> 属性を指定することで
      ディレクトリ全体をアップロードすることができます。
      この機能はほとんどのモダンなブラウザでサポートされています。
     </p></div>
     <div class="example-contents"><p>
      <code class="literal">full_path</code> の情報を使うと、
      相対パスを保存することもできますし、
      サーバー上で同じディレクトリを再構築することもできます。
     </p></div>
     <div class="example-contents">
<div class="htmlcode"><pre class="htmlcode">&lt;form action=&quot;file-upload.php&quot; method=&quot;post&quot; enctype=&quot;multipart/form-data&quot;&gt;
  Send this directory:&lt;br /&gt;
  &lt;input name=&quot;userfile[]&quot; type=&quot;file&quot; webkitdirectory multiple /&gt;
  &lt;input type=&quot;submit&quot; value=&quot;Send files&quot; /&gt;
&lt;/form&gt;</pre>
</div>
     </div>

    </div>

    <div class="warning"><strong class="warning">警告</strong>
     <p class="simpara">
      <code class="literal">webkitdirectory</code> 属性は標準ではありませんし、
      標準化の過程にも入っていません。
      この属性を Web 上の本番環境で使わないで下さい:
      なぜなら、この属性を全ユーザーが使えるとは限らないからです。
      また、この属性はクライアントの実装に非互換がある可能性もありますし、
      振る舞いが将来変更される可能性もあります。
     </p>
     <p class="simpara">
      PHP は ブラウザ/ユーザーエージェントから送られてきた相対パスの情報をパースし、
      その情報を <var class="varname"><a href="reserved.variables.files.php" class="classname">$_FILES</a></var> 配列に渡すことだけを行います。
      <code class="literal">full_path</code> 配列中の値が、
      実際のディレクトリ構造を含んでいるという保証はありません。
      よって、PHP アプリケーションはこの情報を信用してはいけません。
     </p>
    </div>
   </p>
  </div><?php manual_footer($setup); ?>