溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php上傳文件有什么常見(jiàn)問(wèn)題

發(fā)布時(shí)間:2021-06-29 10:17:31 來(lái)源:億速云 閱讀:140 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“php上傳文件有什么常見(jiàn)問(wèn)題”,在日常操作中,相信很多人在php上傳文件有什么常見(jiàn)問(wèn)題問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”php上傳文件有什么常見(jiàn)問(wèn)題”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

把php上傳文件時(shí)經(jīng)常碰到的幾個(gè)問(wèn)題總結(jié)一下吧,以后用到時(shí)不用再去找了。

1.先做個(gè)最簡(jiǎn)單的上傳文件

復(fù)制代碼 代碼如下:


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

復(fù)制代碼 代碼如下:


<?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.然后了解超級(jí)全局變量$_FILES的值

復(fù)制代碼 代碼如下:


$_FILES['userfile']['name']
$_FILES['userfile']['type']
$_FILES['userfile']['size']
$_FILES['userfile']['tmp_name']
$_FILES['userfile']['error']

其中,$_FILES['userfile']['error']的所有值:

UPLOAD_ERR_OK 其值為 0,沒(méi)有錯(cuò)誤發(fā)生,文件上傳成功。

UPLOAD_ERR_INI_SIZE 其值為 1,上傳的文件超過(guò)了 php.ini 中 upload_max_filesize 選項(xiàng)限制的值。

UPLOAD_ERR_FORM_SIZE 其值為 2,上傳文件的大小超過(guò)了 HTML 表單中 MAX_FILE_SIZE 選項(xiàng)指定的值。

UPLOAD_ERR_PARTIAL 其值為 3,文件只有部分被上傳。

UPLOAD_ERR_NO_FILE 其值為 4,沒(méi)有文件被上傳。

UPLOAD_ERR_NO_TMP_DIR 其值為 6,找不到臨時(shí)文件夾。PHP 4.3.10 和 PHP 5.0.3 引進(jìn)。

UPLOAD_ERR_CANT_WRITE 其值為 7,文件寫入失敗。PHP 5.1.0 引進(jìn)。

3.很多情況:需要嚴(yán)格判斷上傳文件類型

     我們知道使用$_FILES['userfile']['type']判斷上傳文件類型是一個(gè)很不明智的做法,因?yàn)樵撆袛嘁罁?jù)是文件的后綴名,任何人都可以將一個(gè)mp3文件的后綴改成jpg從而偽裝成圖片進(jìn)行上傳,因此php官方建議使用php的擴(kuò)展php_fileinfo來(lái)判斷文件的mime,開啟拓展的方法百度一下有很多,win和linux略有不同。

4.情景一:上傳文件重名后自動(dòng)重命名

復(fù)制代碼 代碼如下:


if (file_exists("./upload/" . $_FILES["file"]["name"])) 
{   
   do{ 
       $suffix =""; 
       $suffix_length = 4; 
       $str = "0123456789abcdefghijklmnopqrstuvwxyz"; 
       $len = strlen($str)-1;
       //文件名后追加4個(gè)隨機(jī)字符 
       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.情景二:根據(jù)日期分目錄上傳文件

復(fù)制代碼 代碼如下:


$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.情景三:多文件上傳

復(fù)制代碼 代碼如下:


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

復(fù)制代碼 代碼如下:


 <?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");
     }
 }
 ?>

有的情況下多文件的這種變量結(jié)構(gòu)并不好用:

復(fù)制代碼 代碼如下:


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

很多情況下我們需要的是類似這樣的結(jié)構(gòu)

復(fù)制代碼 代碼如下:


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

使用下面的函數(shù)就能輕松轉(zhuǎn)化結(jié)構(gòu)

復(fù)制代碼 代碼如下:


 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. 有的時(shí)候:需要配置服務(wù)器修改最大上傳文件大小

首先,在表單上

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

然后在服務(wù)器上也需要調(diào)整一下配置

php.ini:

max_execution_time = 30 每個(gè)腳本運(yùn)行的最長(zhǎng)時(shí)間,單位秒
max_input_time = 60,每個(gè)腳本可以消耗的時(shí)間,單位也是秒
memory_limit = 128M,這個(gè)是腳本運(yùn)行最大消耗的內(nèi)存
post_max_size = 8M,表單提交最大數(shù)據(jù)為 8M,此項(xiàng)不是限制上傳單個(gè)文件的大小,而是針對(duì)整個(gè)表單的提交數(shù)據(jù)進(jìn)行限制的。
upload_max_filesize = 2M ,上載文件的最大許可大小

nginx:

復(fù)制代碼 代碼如下:


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

到此,關(guān)于“php上傳文件有什么常見(jiàn)問(wèn)題”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI