用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

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

时间:2015-01-23  来源:西部数据  作者:西部数据

$_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]获取文件信息时会报异常.

测试

实例代码如下:

  1. <html> 
  2. <body> 
  3. <form action="upload_file.php教程" method="post" 
  4. enctype="multipart/form-data"
  5. <label for="file">filename:</label> 
  6. <input type="file" name="file" id="file" />  
  7. <br /> 
  8. <input type="submit" name="submit" value="submit" /> 
  9. </form> 
  10. </body> 
  11. </html> 

php代码

实例代码如下:

  1. <?php 
  2. if ((($_files["file"]["type"] == "image/gif"
  3. || ($_files["file"]["type"] == "image/jpeg"
  4. || ($_files["file"]["type"] == "image/pjpeg")) 
  5. && ($_files["file"]["size"] < 20000)) 
  6.   { 
  7.   if ($_files["file"]["error"] > 0) 
  8.     { 
  9.     echo "error: " . $_files["file"]["error"] . "<br />"
  10.     } 
  11.   else 
  12.     { 
  13.     echo "upload: " . $_files["file"]["name"] . "<br />"
  14.     echo "type: " . $_files["file"]["type"] . "<br />"
  15.     echo "size: " . ($_files["file"]["size"] / 1024) . " kb<br />"
  16.     echo "stored in: " . $_files["file"]["tmp_name"]; 
  17.     } 
  18.   } 
  19. else 
  20.   { 
  21.   echo "invalid file"
  22.   } 
  23. ?> 

文件上传精简代码,实例代码如下:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  2. <html xmlns="http://www.w3.org/1999/xhtml"
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  5. <title>Excel数据获取演示</title> 
  6. <meta name="Keywords" content="TODO" /> 
  7. <meta name="Description" content="TODO"/> 
  8. </head> 
  9. <body> 
  10.     <div> 
  11.       <div>提交表单</div> 
  12.       <div> 
  13.         <form method="POST" action="www.111cn.net/Index/parse" enctype="multipart/form-data"
  14.             <input type="file" name="excel" value="" /> 
  15.             <input type="submit" name="submit" value="提交" /> 
  16.         </form> 
  17.       </div> 
  18.     </div> 
  19. </body> 
  20. </html> 
  21. public function parse() 
  22.     { 
  23.        /** 
  24.         * $_FILES数组说明 
  25.         * array(n) { 
  26.         *   ["表单文件框名称"] => array(5) { 
  27.         *       ["name"]        => 提交文件名称 
  28.         *       ["type"]        => 提交文件类型 Excel为"application/vnd.ms-excel" 
  29.         *       ["tmp_name"]    => 临时文件名称 
  30.         *       ["error"]       => 错误(0成功1文件太大超过upload_max_filesize2文件太大超过MAX_FILE3上传不完整4没有上传文件) 
  31.         *       ["size"]        => 文件大小(单位:KB) 
  32.         *   } 
  33.         * } 
  34.         */ 
  35.         $return=array(0,''); 
  36.         /** 
  37.          * 判断是否提交 
  38.          * is_uploaded_file(文件名称)用于确定指定的文件是否使用POST方法上传,防止非法提交,通常和move_upload_file一起使用保存上传文件到指定的路径 
  39.          */ 
  40.         if(!isset($_FILES) || !is_uploaded_file($_FILES['excel']['tmp_name'])) 
  41.         { 
  42.             $return=array(1,'提交不合法'); 
  43.         } 
  44.         //处理 
  45.         if(0 == $return[0]) 
  46.         { 
  47.             import('@.Util.ExcelParser'); 
  48.             $excel=new ExcelParser($_FILES['excel']['tmp_name']); 
  49.             $return=$excel->main(); 
  50.         } 
  51.         //输出处理 
  52.         print_r($return); 
  53. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门