• php实用的文件上传类


     1 <?php
     2 class Upload {
     3     //确定属性
     4     private $_max_size;
     5     private $_ext_list= array('.jpg','.png','.gif');
     6     private $_allow_mine_list= array('image/pgn','image/gif','image/jpeg','image/pjpeg','image/x-png');
     7     private $_upload_path;
     8     private $_prefix;
     9     public function __construct()
    10     {
    11         $this -> setMaxsize(4*1024*1024);
    12     }
    13     //给出对应的set方法
    14     public function setMaxsize($max_size){
    15         $this->_max_size=$max_size;
    16     }
    17     
    18     public function setExtList(array $ext_list = array('.jpg','.png','.gif')){
    19         $this->_ext_list=$ext_list;
    20     }
    21     
    22     public function setAllowMimeList(array $allow_mine_list=array('image/pgn','image/gif','image/jpeg','image/pjpeg','image/x-png')){
    23         $this->_allow_mine_list=$allow_mine_list;
    24     }
    25     
    26     public function setUploadPath ($upload_path){
    27         $this->_upload_path=$upload_path;
    28     }
    29     public function setPrefix($prefix){
    30         $this->_prefix=$prefix;
    31     }
    32     
    33     public function doUpload($tmp_file){
    34         //判断文件大小,当文件过大时给出提示,放弃上传
    35         if($tmp_file['size']>$this->_max_size){
    36             echo '你上传的文件过大';
    37             return false ;
    38         }
    39         if(!($tmp_file['error']===0)){
    40             echo '上传文件有误';
    41             return false ;
    42         }
    43         //增加一段代码,用来校验上传的文件类型是否正确
    44         //上传文件的后缀统一转成小写
    45         $ext = strtolower(strrchr($tmp_file['name'],'.'));
    46         
    47         if(!in_array($ext, $this->_ext_list)){
    48             echo '你上传的文件类型不对';
    49             return false;
    50         }
    51         //对文件进行第二级防护,对上传文件的MIME进行验证
    52         $mime_type =$tmp_file['type'];
    53         if(!in_array($mime_type, $this->_allow_mine_list)){
    54             echo '你上传的文件的mime不对';
    55             return false;
    56         }
    57         //对文件类型进行第三级防护,使用PHP程序对文件类型进行MIME检测
    58         //为了使用Finfo这个类,需要开启php.ini中一个扩展:extension php_fileinfo.dll
    59         $finfo = new Finfo(FILEINFO_MIME_TYPE);
    60         $mime_type=$finfo->file($tmp_file['tmp_name']);
    61         if (!in_array($mime_type, $this->_allow_mine_list)){
    62             echo '类型不合法';
    63             return false;
    64         }
    65         //这里我们增加一段代码,让文件名唯一
    66         $filename = uniqid($this->_prefix,true);
    67         //拼接一个完整唯一的文件名
    68         $upload_filename=$filename.$ext;
    69         
    70         //增加分目录存放处理,记得在最后带上/
    71         $sub_dir = date('Ymd').'/';
    72         //判断这个目录是否存在
    73         if (!is_dir($this->_upload_path.$sub_dir)){
    74             //如果目录不存在,则创建一个新的
    75             mkdir($this->_upload_path.$sub_dir,0777,true);
    76         }
    77         if (move_uploaded_file(iconv('gbk','utf-8',$tmp_file['tmp_name']), iconv('utf-8','gbk',$this->_upload_path.$sub_dir.$upload_filename))){
    78             return $sub_dir.$upload_filename;
    79         }else{
    80             return false;
    81         }
    82     }
    83 }
  • 相关阅读:
    Linux下压缩文件和解压缩
    原生JS随机数
    Git问题-Git warning LF will be replaced by CRLF
    mysql进程占用cpu居高不下处理
    mysql修改查询的结果包含的敏感字
    mysql 全库备份和还原
    mysql创建用户并设置权限
    Mysql-开启 SSL加密 mysql_ssl_rsa_setup
    tp6_005控制器
    ERROR 1104 (42000): The SELECT would examine more than MAX_JOIN_SIZE rows; check your WHERE and use SET SQL_BIG_SELECTS=1 or SET MAX_JOIN_SIZE=# if the SELECT is okay
  • 原文地址:https://www.cnblogs.com/ggkxg/p/5679056.html
Copyright © 2020-2023  润新知