1九、PHP傳統文件上傳和Base64位文件上傳

 

1、基本知識php

    經過使用 PHP 的全局數組 $_FILES,你能夠從客戶計算機向遠程服務器上傳文件。html

    第一個參數是表單的 input name,第二個下標能夠是 "name", "type", "size", "tmp_name" 或 "error"。就像這樣:web

  • $_FILES["file"]["name"] - 被上傳文件的名稱數組

  • $_FILES["file"]["type"] - 被上傳文件的類型安全

  • $_FILES["file"]["size"] - 被上傳文件的大小,以字節計服務器

  • $_FILES["file"]["tmp_name"] - 存儲在服務器的文件的臨時副本的名稱post

  • $_FILES["file"]["error"] - 由文件上傳致使的錯誤代碼編碼

    這是一種很是簡單文件上傳方式。基於安全方面的考慮,您應當增長有關什麼用戶有權上傳文件的限制。spa

 

2、經常使用上傳code

<?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>

3、php讀取和保存base64編碼的圖片內容

<?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>
相關文章
相關標籤/搜索