php文件上传

<?php
    $allowtype = array("gif", "png", "jpg");   //设置充许上传的类型为gif, png和jpg
    $size = 1000000;                           //设置充许大小为1M(1000000字节)以内的文件
    $path = "./uploads";                       //设置上传后保存文件的路径
    
    //判断文件是否可以成功上传到服务器,$_FILES['myfile']['error'] 为0表示上传成功
    if($_FILES['myfile']['error'] > 0) {      
        echo '上传错误: ';
        switch ($_FILES['myfile']['error']) {
             case 1:  die('上传文件大小超出了PHP配置文件中的约定值:upload_max_filesize');  
            case 2:  die('上传文件大小超出了表单中的约定值:MAX_FILE_SIZE');  
            case 3:  die('文件只被部分上载'); 
            case 4:  die('没有上传任何文件'); 
            default: die('末知错误');
           }
    }
    
    //判断上传的文件是否为充许的文件类型,通过文件的后缀名
    $hz = array_pop(explode(".", $_FILES['myfile']['name']));
    //通过判断文件的后缀方式,来决定文件是否是充许上传的文件类型
    if(!in_array($hz, $allowtype)) {
        die("这个后缀是<b>{$hz}</b>,不是充许的文件类型!");
    }
    
    /* 也可以通过获取上传文件的MIME类型中的主类型和子类型,来限制文件上传的类型
    list($maintype,$subtype)=explode("/",$_FILES['myfile']['type']);    
      if ($maintype=="text") {   //通过主类型限制不能上传文本文件,例如.txt .html .php等文件
        die('问题: 不能上传文本文件。');
    } */

    //判断上传的文件是否为充许大小
    if($_FILES['myfile']['size'] > $size ) {
        die("超过了充许的<b>{$size}</b>字节大小");
    }
    
    //为了系统安全,也为了同名文件不会被覆盖,上传后将文件名使用系统定义
    $filename = date("YmdHis").rand(100,999).".".$hz;
    
    //判断是否为上传文件
    if (is_uploaded_file($_FILES['myfile']['tmp_name'])) { 
         if (!move_uploaded_file($_FILES['myfile']['tmp_name'], $path.'/'.$filename)) {  
            die('问题: 不能将文件移动到指定目录。');
        }
     }else{
        die("问题: 上传文件{$_FILES['myfile']['name']}不是一个合法文件: ");
    }

    //如果文件上传成功则输出
    echo "文件{$upfile}上传成功,保存在目录{$path}中,大小为{$_FILES['myfile']['size']}字节";   

 

posted @ 2015-12-04 04:40  对数螺旋线  阅读(396)  评论(2编辑  收藏  举报