19、PHP伝統ファイルアップロードとBase 64ビットファイルアップロード

3582 ワード


一、基本知識
PHPを使用したグローバル配列$FILESでは、クライアントコンピュータからリモートサーバにファイルをアップロードできます.
最初のパラメータはフォームのinput nameで、2番目の下付き文字は「name」、「type」、「size」、「tmp_name」または「error」です.このように:
  • $_FILES[file][name]-アップロードされたファイルの名前
  • $_FILES[file][type]-アップロードされるファイルのタイプ
  • $_FILES[file][size]-アップロードされたファイルのサイズは、
  • バイトです.
  • $_FILES[file][tmp_name]-サーバに格納ファイルの一時コピーの名前
  • $_FILES[file][error]-ファイルアップロードによるエラーコード
  • これは非常に簡単なファイルアップロード方法です.セキュリティ上の考慮に基づいて、どのユーザーがファイルをアップロードする権利があるかに関する制限を追加する必要があります.
     
    二、よくアップロードする
    <?php
    if ((($_FILES["file"]["type"] == "image/gif")
    || ($_FILES["file"]["type"] == "image/jpeg")
    || ($_FILES["file"]["type"] == "image/pjpeg"))
    && ($_FILES["file"]["size"] < 20000))
      {
      if ($_FILES["file"]["error"] > 0)
        {
        echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
        }
      else
        {
        echo "Upload: " . $_FILES["file"]["name"] . "<br />";
        echo "Type: " . $_FILES["file"]["type"] . "<br />";
        echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
        echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
    
        if (file_exists("upload/" . $_FILES["file"]["name"]))
          {
          echo $_FILES["file"]["name"] . " already exists. ";
          }
        else
          {
          move_uploaded_file($_FILES["file"]["tmp_name"],
          "upload/" . $_FILES["file"]["name"]);
          echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
          }
        }
      }
    else
      {
      echo "Invalid file";
      }
    ?> 
    
    <html>
    <body>
        <form action="" method="post" enctype="multipart/form-data">
        <label for="file">Filename:</label>
        <input type="file" name="file" id="file" /> 
        <br />
        <input type="submit" name="submit" value="Submit" />
        </form>
    </body>
    </html>

    三、phpはbase 64符号化されたピクチャの内容を読み取り、保存する
    <?php
    if($_POST['submit']){
        $image_info = getimagesize($_FILES['file']['tmp_name']);//$_FILES['file']['tmp_name']     
        $base64_image_content = "data:{$image_info['mime']};base64," . chunk_split(base64_encode(file_get_contents($_FILES['file']['tmp_name'])));
        echo $base64_image_content;die; 
        if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
            $type = $result[2];
            $new_file = "./test.{$type}";
            if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){
              echo '       :', $new_file;
            }
        }
    }
    ?>
    <html>
    <body>
        <form action="" method="post" enctype="multipart/form-data">
        <label for="file">Filename:</label>
        <input type="file" name="file" id="file" /> 
        <br />
        <input type="submit" name="submit" value="Submit" />
        </form>
    </body>
    </html>