国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php上傳文件常見問題總結

2024-05-04 23:30:54
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了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,沒有錯誤發生,文件上傳成功。

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="字節" />
可以限制上傳文件大小(可以被繞過)。

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

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;
  }

 

以上就是常見的問題的處理方法了,希望大家能夠喜歡。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 轮台县| 郧西县| 长葛市| 海伦市| 高平市| 鹿邑县| 文昌市| 枞阳县| 桂平市| 梁平县| 于田县| 乐都县| 大渡口区| 包头市| 阳东县| 巫溪县| 彰武县| 奈曼旗| 滁州市| 高要市| 大兴区| 汶上县| 蓬安县| 武定县| 河曲县| 孟州市| 个旧市| 永寿县| 平罗县| 历史| 松江区| 云霄县| 横峰县| 徐州市| 嵊泗县| 波密县| 太仆寺旗| 嘉鱼县| 什邡市| 板桥市| 密云县|