溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php上傳文件的操作

發(fā)布時間:2021-06-29 14:14:20 來源:億速云 閱讀:114 作者:chen 欄目:開發(fā)技術

本篇內容主要講解“php上傳文件的操作”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“php上傳文件的操作”吧!

1.先做個最簡單的上傳文件

復制代碼 代碼如下:

<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 </head>
 <body>
 <form action="upload_file.php" 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
 if (($_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";
   }
 ?>

2.然后了解超級全局變量$_FILES的值

復制代碼 代碼如下:

$_FILES['userfile']['name']$_FILES['userfile']['type']$_FILES['userfile']['size']$_FILES['userfile']['tmp_name']$_FILES['userfile']['error']
其中,$_FILES['userfile']['error']的所有值:
UPLOAD_ERR_OK 其值為 0,沒有錯誤發(fā)生,文件上傳成功。
UPLOAD_ERR_INI_SIZE 其值為 1,上傳的文件超過了 php.ini 中 upload_max_filesize 選項限制的值。
UPLOAD_ERR_FORM_SIZE 其值為 2,上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值。
UPLOAD_ERR_PARTIAL 其值為 3,文件只有部分被上傳。
UPLOAD_ERR_NO_FILE 其值為 4,沒有文件被上傳。
UPLOAD_ERR_NO_TMP_DIR 其值為 6,找不到臨時文件夾。PHP 4.3.10 和 PHP 5.0.3 引進。
UPLOAD_ERR_CANT_WRITE 其值為 7,文件寫入失敗。PHP 5.1.0 引進。

3.很多情況:需要嚴格判斷上傳文件類型

     我們知道使用$_FILES['userfile']['type']判斷上傳文件類型是一個很不明智的做法,因為該判斷依據是文件的后綴名,任何人都可以將一個mp3文件的后綴改成jpg從而偽裝成圖片進行上傳,因此php官方建議使用php的擴展php_fileinfo來判斷文件的mime,開啟拓展的方法百度一下有很多,win和linux略有不同。

4.情景一:上傳文件重名后自動重命名

復制代碼 代碼如下:

if (file_exists("./upload/" . $_FILES["file"]["name"]))  
{    
   do{  
       $suffix ="";  
       $suffix_length = 4;  
       $str = "0123456789abcdefghijklmnopqrstuvwxyz";  
       $len = strlen($str)-1; 
       //文件名后追加4個隨機字符  
       for($i=0 ; $i<$suffix_length; $i++){  
          $suffix .= $str[rand(0,$len)];  
       }  
       $upload_filename = $_FILES['file']['name'];                                            
       $filename = substr($upload_filename,0,strrpos($upload_filename,".")).$suffix.".".substr($upload_filename,strrpos($_FILES["file"]["name"],".")+1); 
   }while(file_exists("./upload/".$filename));  
       move_uploaded_file($_FILES["file"]["tmp_name"],"./upload/" . $filename);  
}else{  
       move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);   
}

5.情景二:根據日期分目錄上傳文件

復制代碼 代碼如下:

$structure = './'.date("Y").'/'.date("m").'/'.date("d").'/';
 if (!mkdir($structure, 0777, true)) {
     die('Failed to create folders...');
 }
 move_uploaded_file($_FILES["file"]["tmp_name"],$structure . $_FILES["file"]["name"]);

6.情景三:多文件上傳

復制代碼 代碼如下:

 <form action="" method="post" enctype="multipart/form-data">
 <p>Pictures:
 <input type="file" name="pictures[]" />
 <input type="file" name="pictures[]" />
 <input type="file" name="pictures[]" />
 <input type="submit" value="Send" />
 </p>
 </form>

復制代碼 代碼如下:

<?php
 foreach ($_FILES["pictures"]["error"] as $key => $error) {
     if ($error == UPLOAD_ERR_OK) {
         $tmp_name = $_FILES["pictures"]["tmp_name"][$key];
         $name = $_FILES["pictures"]["name"][$key];
         move_uploaded_file($tmp_name, "data/$name");
     }
 }
 ?>


 
有的情況下多文件的這種變量結構并不好用:

復制代碼 代碼如下:

array(1) {    ["upload"]=>array(2) {        ["name"]=>array(2) {            [0]=>string(9)"file0.txt"            [1]=>string(9)"file1.txt"        }        ["type"]=>array(2) {            [0]=>string(10)"text/plain"            [1]=>string(10)"text/html"        }    }}

很多情況下我們需要的是類似這樣的結構

復制代碼 代碼如下:

array(1) {
    ["upload"]=>array(2) {
        [0]=>array(2) {
            ["name"]=>string(9)"file0.txt"
            ["type"]=>string(10)"text/plain"
        },
        [1]=>array(2) {
            ["name"]=>string(9)"file1.txt"
            ["type"]=>string(10)"text/html"
        }
}
}

使用下面的函數就能輕松轉化結構

復制代碼 代碼如下:

function diverse_array($vector) { 
     $result = array(); 
     foreach($vector as $key1 => $value1) 
         foreach($value1 as $key2 => $value2) 
             $result[$key2][$key1] = $value2; 
     return $result; 
 }

 $upload = diverse_array($_FILES["upload"]);

7. 有的時候:需要配置服務器修改最大上傳文件大小

首先,在表單上

<input type="hidden" name="MAX_FILE_SIZE" value="字節(jié)" />
可以限制上傳文件大小(可以被繞過)。

然后在服務器上也需要調整一下配置

php.ini:

復制代碼 代碼如下:

max_execution_time = 30 每個腳本運行的最長時間,單位秒
max_input_time = 60,每個腳本可以消耗的時間,單位也是秒
memory_limit = 128M,這個是腳本運行最大消耗的內存
post_max_size = 8M,表單提交最大數據為 8M,此項不是限制上傳單個文件的大小,而是針對整個表單的提交數據進行限制的。
upload_max_filesize = 2M ,上載文件的最大許可大小

nginx:

復制代碼 代碼如下:

 location / {
     root   html;
     index  index.html index.htm;
     client_max_body_size    1000m;
  }

到此,相信大家對“php上傳文件的操作”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI