$_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
- 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);
- ?>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。