$_FILES: 經(jīng)由 HTTP POST 文件上傳而提交至腳本的變量,類似于舊數(shù)組 $HTTP_POST_FILES 數(shù)組(依然有效,但反對使用)詳細信息可參閱 POST 方法上傳
_FILES數(shù)組內(nèi)容如下:
$_FILES['myFile']['name'] 客戶端文件的原名稱
$_FILES['myFile']['type'] 文件的 MIME 類型,需要瀏覽器提供該信息的支持,例如"image/gif"
$_FILES['myFile']['size'] 已上傳文件的大小,單位為字節(jié)
$_FILES['myFile']['tmp_name'] 文件被上傳后在服務端儲存的臨時文件名,一般是系統(tǒng)默認,可以在php.ini的upload_tmp_dir 指定,但用 putenv() 函數(shù)設置是不起作用的
$_FILES['myFile']['error'] 和該文件上傳相關的錯誤代碼,['error'] 是在 PHP 4.2.0 版本中增加的,下面是它的說明:(它們在PHP3.0以后成了常量)
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; 沒有文件被上傳, 值:5; 上傳文件大小為0
注:
1. 文件被上傳結(jié)束后,默認地被存儲在了臨時目錄中,這時必須將它從臨時目錄中刪除或移動到其它地方,如果沒有,則會被刪除.也就是不管是否上傳成功,腳本執(zhí)行完后臨時目錄里的文件肯定會被刪除.所以在刪除之前要用PHP的 copy() 函數(shù)將它復制到其它位置,此時,才算完成了上傳文件過程.
2. 在 PHP 4.1.0 版本以前該數(shù)組的名稱為 $HTTP_POST_FILES,它并不像 $_FILES 一樣是自動全局變量.PHP 3 不支持 $HTTP_POST_FILES 數(shù)組.
3. 用form上傳文件時,一定要加上屬性內(nèi)容 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數(shù)據(jù)獲取演示</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數(shù)組說明
- * 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);
- ?>
新聞熱點
疑難解答