萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> PHP 中$_FILES的使用及注意事項

PHP 中$_FILES的使用及注意事項

$_FILES: 經由 HTTP POST 文件上傳而提交至腳本的變量,類似於舊數組 $HTTP_POST_FILES 數組(依然有效,但反對使用)詳細信息可參閱 POST 方法上傳

$_FILES數組內容如下:

$_FILES['myFile']['name'] 客戶端文件的原名稱        

$_FILES['myFile']['type'] 文件的 MIME 類型,需要浏覽器提供該信息的支持,例如"image/gif"        

$_FILES['myFile']['size'] 已上傳文件的大小,單位為字節        

$_FILES['myFile']['tmp_name'] 文件被上傳後在服務端儲存的臨時文件名,一般是系統默認,可以在php.ini的upload_tmp_dir 指定,但用 putenv() 函數設置是不起作用的      

$_FILES['myFile']['error'] 和該文件上傳相關的錯誤代碼,['error'] 是在 PHP 4.2.0 版本中增加的,下面是它的說明:(它們在PHP3.0以後成了常量)

    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; 沒有文件被上傳, 值:5; 上傳文件大小為0                      

注:

1. 文件被上傳結束後,默認地被存儲在了臨時目錄中,這時必須將它從臨時目錄中刪除或移動到其它地方,如果沒有,則會被刪除。也就是不管是否上傳成功,腳本執行完後臨時目錄裡的文件肯定會被刪除。所以在刪除之前要用PHP的 copy() 函數將它復制到其它位置,此時,才算完成了上傳文件過程。

2. 在 PHP 4.1.0 版本以前該數組的名稱為 $HTTP_POST_FILES,它並不像 $_FILES 一樣是自動全局變量。PHP 3 不支持 $HTTP_POST_FILES 數組。


3. 用form上傳文件時,一定要加上屬性內容 enctype="multipart/form-data",否則用$_FILES[filename]獲取文件信息時會報異常。


測試

 代碼如下 復制代碼

<html>
<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代碼

 代碼如下 復制代碼

<?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 "error: " . $_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 "stored in: " . $_files["file"]["tmp_name"];
    }
  }
else
  {
  echo "invalid file";
  }

?>

文件上傳精簡代碼

 代碼如下 復制代碼

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Excel數據獲取演示</title>
<meta name="Keywords" content="TODO" />
<meta name="Description" content="TODO"/>
</head>
<body>
    <div>
      <div>提交表單</div>
      <div>
        <form method="POST" action="www.111cn.net/Index/parse" enctype="multipart/form-data">
            <input type="file" name="excel" value="" />
            <input type="submit" name="submit" value="提交" />
        </form>
      </div>
    </div>
</body>
</html>

public function parse()
    {
       /**
        * $_FILES數組說明
        * array(n) {
        *   ["表單文件框名稱"] => array(5) {
        *       ["name"]        => 提交文件名稱
        *       ["type"]        => 提交文件類型 Excel為"application/vnd.ms-excel"
        *       ["tmp_name"]    => 臨時文件名稱
        *       ["error"]       => 錯誤(0成功1文件太大超過upload_max_filesize2文件太大超過MAX_FILE3上傳不完整4沒有上傳文件)
        *       ["size"]        => 文件大小(單位:KB)
        *   }
        * }
        */
        $return=array(0,'');
        /**
         * 判斷是否提交
         * is_uploaded_file(文件名稱)用於確定指定的文件是否使用POST方法上傳,防止非法提交,通常和move_upload_file一起使用保存上傳文件到指定的路徑
         */
        if(!isset($_FILES) || !is_uploaded_file($_FILES['excel']['tmp_name']))
        {
            $return=array(1,'提交不合法');
        }
        //處理
        if(0 == $return[0])
        {
            import('@.Util.ExcelParser');
            $excel=new ExcelParser($_FILES['excel']['tmp_name']);
            $return=$excel->main();
        }
        //輸出處理
        print_r($return);
?>

更多詳細內容請查看:http://www.111cn.net/phper/21/4662008ae09ff36c1a029763e9dcacf2.htm

copyright © 萬盛學電腦網 all rights reserved