首页 > php教程 > php手册 > PHP 中$_FILES的使用及注意事项

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

WBOY
发布: 2016-05-25 16:47:00
原创
980 人浏览过

$_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> 
<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>
登录后复制
<?php
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,
        &#39;&#39;
    );
    /** 
     * 判断是否提交
     * is_uploaded_file(文件名称)用于确定指定的文件是否使用POST方法上传,防止非法提交,通常和move_upload_file一起使用保存上传文件到指定的路径
     */
    if (!isset($_FILES) || !is_uploaded_file($_FILES[&#39;excel&#39;][&#39;tmp_name&#39;])) {
        $return = array(
            1,
            &#39;提交不合法&#39;
        );
    }
    //处理
    if (0 == $return[0]) {
        import(&#39;@.Util.ExcelParser&#39;);
        $excel = new ExcelParser($_FILES[&#39;excel&#39;][&#39;tmp_name&#39;]);
        $return = $excel->main();
    }
    //输出处理
    print_r($return);
?>
登录后复制


教程地址:

欢迎转载!但请带上文章地址^^

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板