A-A+

php文件上传类与详解

2019年09月23日 我爱编程 暂无评论

php 配置中的 upload_tmp_dir 这个参数进行比较,如果文件在这个目录下面,那么 move_uploaded_file 才会进行移动操作,而且这个比较是大小写敏感,/ 在windows 下面也是不一样的,而在php配置文件解析的时候,会调用一个realpath 函数,也就是是说,你在move_uploaded_file 之前.

必须对$file['tmp_name'] = realpath($file['tmp_name']); realpath 一下.

还有一种情况,大家要注意,就是 move_uploaded_file 如果配置成一个无法访问的路径,那么你不管怎么处理,move_uploaded_file 总是不能成功移动文件.

在文件上传的时候,用 move_uploaded_file 这个函数不能移动文件,而用copy 或者 rename 确是可以的.

我也一直很困惑,在文档上,说的比较模糊,就是 move_uploaded_file 这个函数,加了一步检查,检查这个文件是否是有 http post 上传的.

下面我在网上找到一个文件上传类,实例代码如下:

  1. **文件上传类**/
  2. class upload_file
  3.  {
  4.   /**声明**/
  5.   var $upfile_type,$upfile_size,$upfile_name,$upfile;
  6.   var $d_alt,$extention_list,$tmp,$arri;
  7.   var $datetime,$date;
  8.   var $filestr,$size,$ext,$check;
  9.   var $flash_directory,$extention,$file_path,$base_directory;
  10.   var $url//文件上传成功后跳转路径;
  11.   function upload_file()
  12.   {
  13.    /**构造函数**/
  14.    $this->set_url("index.php");          //初始化上传成功后跳转路径;
  15.    $this->set_extention();             //初始化扩展名列表;
  16.    $this->set_size(50);              //初始化上传文件kb限制;
  17.    $this->set_date();               //设置目录名称;
  18.    $this->set_datetime();             //设置文件名称前缀;
  19.    $this->set_base_directory("attachmentfile");  //初始化文件上传根目录名,可修改!;
  20.   }
  21.   /**文件类型**/
  22.   function set_file_type($upfile_type)
  23.   {
  24.    $this->upfile_type = $upfile_type;       //取得文件类型;
  25.   }
  26.   /**获得文件名**/
  27.   function set_file_name($upfile_name)
  28.   {
  29.    $this->upfile_name = $upfile_name;       //取得文件名称;
  30.   }
  31.   /**获得文件**/
  32.   function set_upfile($upfile)
  33.   {
  34.    $this->upfile = $upfile;            //取得文件在服务端储存的临时文件名;
  35.   }
  36.   /**获得文件大小**/
  37.   function set_file_size($upfile_size)
  38.   {
  39.    $this->upfile_size = $upfile_size;       //取得文件尺寸;
  40.   }
  41.   /**设置文件上传成功后跳转路径**/
  42.   function set_url($url)
  43.   {
  44.    $this->url = $url;               //设置成功上传文件后的跳转路径;
  45.   }
  46.   /**获得文件扩展名**/
  47.   function get_extention()
  48.   {
  49.     $this->extention = preg_replace('/.*.(.*[^.].*)*/iu','1',$this->upfile_name); //取得文件扩展名;
  50.   }
  51.   /**设置文件名称**/
  52.   function set_datetime()
  53.   {
  54.    $this->datetime = date("ymdhis");        //按时间生成文件名;
  55.   }
  56.   /**设置目录名称**/
  57.   function set_date()
  58.   {
  59.    $this->date = date("y-m-d");          //按日期生成目录名称;
  60.   }
  61.   /**初始化允许上传文件类型**/
  62.   function set_extention()
  63.   {
  64.    $this->extention_list = "doc|xls|ppt|avi|txt|gif|jpg|jpeg|bmp|png"//默认允许上传的扩展名称;
  65.   }
  66.   /**设置最大上传kb限制**/
  67.   function set_size($size)
  68.   {
  69.    $this->size = $size;              //设置最大允许上传的文件大小;
  70.   }
  71.   /**初始化文件存储根目录**/
  72.   function set_base_directory($directory)
  73.   {
  74.    $this->base_directory = $directory//生成文件存储根目录;
  75.   }
  76.   /**初始化文件存储子目录**/
  77.   function set_flash_directory()
  78.   {
  79.    $this->flash_directory = $this->base_directory."/".$this->date//生成文件存储子目录;
  80.   }
  81.   /**错误处理**/
  82.   function showerror($errstr="未知错误!"){
  83.    echo "<script language=网页特效>alert('$errstr');location='javascript:history.go(-1);';</script>";
  84.    exit();
  85.   }
  86.   /**跳转**/
  87.   function go_to($str,$url)
  88.   {
  89.    echo "<script language='javascript'>alert('$str');location='$url';</script>";
  90.    exit();
  91.   }
  92.   /**如果根目录没有创建则创建文件存储目录**/
  93.   function mk_base_dir()
  94.   {
  95.    if (! file_exists($this->base_directory)){   //检测根目录是否存在;
  96.     @mkdir($this->base_directory,0777);     //不存在则创建;
  97.    }
  98.   }
  99.   /**如果子目录没有创建则创建文件存储目录**/
  100.   function mk_dir()
  101.   {
  102.    if (! file_exists($this->flash_directory)){   //检测子目录是否存在;
  103.     @mkdir($this->flash_directory,0777);     //不存在则创建;
  104.    }
  105.   }
  106.   /**以数组的形式获得分解后的允许上传的文件类型**/
  107.   function get_compare_extention()
  108.   {
  109.    $this->ext = explode("|",$this->extention_list);//以"|"来分解默认扩展名;
  110.   }
  111.   /**检测扩展名是否违规**/
  112.   function check_extention()
  113.   {
  114.    for($i=0;each($this->ext);$i++)            //遍历数组;
  115.    {
  116.     if($this->ext[$i] == strtolower($this->extention)) //比较文件扩展名是否与默认允许的扩展名相符;
  117.     {
  118.      $this->check = true;               //相符则标记;
  119.      break;
  120.     }
  121.    }
  122.    if(!$this->check){$this->showerror("正确的扩展名必须为".$this->extention_list."其中的一种!");}
  123.    //不符则警告
  124.   }
  125.   /**检测文件大小是否超标**/
  126.   function check_size()
  127.   {
  128.    if($this->upfile_size > round($this->size*1024))     //文件的大小是否超过了默认的尺寸;
  129.    {
  130.     $this->showerror("上传附件不得超过".$this->size."kb"); //超过则警告;
  131.    }
  132.   }
  133.   /**文件完整访问路径**/
  134.   function set_file_path()
  135.   {
  136.    $this->file_path = $this->flash_directory."/".$this->datetime.".".$this->extention; //生成文件完整访问路径;
  137.   }
  138.   /**上传文件**/
  139.   function copy_file()
  140.   {
  141.    if(copy($this->upfile,$this->file_path)){        //上传文件;
  142.     print $this->go_to("文件已经成功上传!",$this->url);  //上传成功;
  143.    }else {
  144.     print $this->showerror("意外错误,请重试!");     //上传失败;
  145.    }
  146.   }
  147.   /**完成保存**/
  148.   function save()
  149.   {
  150.    $this->set_flash_directory();  //初始化文件上传子目录名;
  151.    $this->get_extention();     //获得文件扩展名;
  152.    $this->get_compare_extention(); //以"|"来分解默认扩展名;
  153.    $this->check_extention();    //检测文件扩展名是否违规;
  154.    $this->check_size();      //检测文件大小是否超限;   
  155.    $this->mk_base_dir();      //如果根目录不存在则创建;
  156.    $this->mk_dir();        //如果子目录不存在则创建;
  157.    $this->set_file_path();     //生成文件完整访问路径;
  158.    $this->copy_file();       //上传文件;
  159.   }
  160.  }

调用方法,实例代码如下,upload.htm @ 表单文件名:

  1. <html>
  2. <head>
  3.   <title>文件上传实例</title>
  4. </head>
  5. <body>
  6.  <form action="test.php" method="post" enctype="multipart/form-data">
  7. <table border=0 cellpadding=3 cellspacing=4 width=30%>
  8.  <tr>
  9.   <td width=10% nowrap>附件来源</td>
  10.   <td><input name="src" type="file"/></td>
  11.  </tr>
  12.  <tr>
  13.   <td colspan=2 align=center><input type="submit" value="上传"></td>
  14.  </tr>
  15. </table>
  16. </form>
  17. </body>
  18. </html>

test.php @ 处理表单文件名,实例代码如下:

  1. <?php
  2.   include("upload.php");                 # 加入类文件
  3.    $f_upload = new upload_other;             # 创建对象
  4.    $f_upload->set_file_type($_files['src']['type']);   # 获得文件类型
  5.    $f_upload->set_file_name($_files['src']['name']);   # 获得文件名称
  6.    $f_upload->set_file_size($_files['src']['size']);   # 获得文件尺寸
  7.    $f_upload->set_upfile($_files['src']['tmp_name']);  # 服务端储存的临时文件名
  8.    $f_upload->set_size(100);               # 设置最大上传kb数
  9.     $f_upload->set_base_directory("uploadimages");    # 文件存储根目录名称
  10.    $f_upload->set_url("up.php");             # 文件上传成功后跳转的文件
  11.    $f_upload->save();                  # 保存文件
  12.    ?>

没有在类里做有无文件的验证,大家可以在前台搞定.

给我留言

Copyright © 四季博客 保留所有权利.   Theme  Ality

用户登录