首页 > 开发 > PHP > 正文

PHP文件操作实例总结【文件上传、下载、分页】

2024-05-04 22:41:48
字体:
来源:转载
供稿:网友

本文实例讲述了PHP文件操作。分享给大家供大家参考,具体如下:

1、文件上传

上传域: input type="file"

普通文本框(text、password、textarea、radio、checkbox等):通过字节流的形式将数据提交到服务器

文件: 将文件以二进制编码的形式提交过去,实现起来非常简单,只需要在form标签中增加 enctype="multipart/form-data"

<!-- 例如 --><form action="" method="post" enctype="multipart/form-data" >  <input type="file" name=""></form>

客户端提交文件之后服务器端接受用 $_FILES 接收

所谓文件上传就是将上图的临时文件移动到指定的目的地

使用函数 move_uploaded_file( file,newpath) 返回bool值

1.1 文件上传案例

// 例如move_uploaded_file($_FILES['myfile']['tmp_name'], 'd:/upload/');

1.2 防止上传文件过大

知识

1GB == 1024MB
1MB == 1024KB
1KB == 1024Byte

$max_size = 3*1024*1024; // 约束为3Mif($_FILES['myfile']['size'] > $max_size){  echo '上传图片大于3M';  exit;}// 上传if(move_uploaded_file($_FILES['myfile']['tmp_name'], $path)){  echo '上传成功';} else {  echo '上传失败';}

注意 php.ini 文件可以修改上传文件限制: 是否允许上传、上传的临时目录、文件最大限制、一次上传最大数量

1.3 防止文件被覆盖

1、我们在服务器端进行验证,在移动到目的地的时候,生成新的文件名时,使用随机数命名,可以避免文件名重复
2、按日期保存文件夹

1.4 控制上传的文件类型

一般需求是:.jpg .png .gif 格式的图片

防止修改文件后缀然后上传,可以借助php的扩展 Finfo,更加精确的获得文件的类型

// 为了防止用户修改文件后缀,使用php的一个扩展 Finfo 实现# 1、开启php.ini 中php扩展extension=php_fileinfo.dll# 2、使用扩展类获取上传文件真实类型$finfo = new Finfo(FILEINFO_MIME_TYPE);$mime_type = $finfo->file($_FILES['myfile']['tmp_name']);

自己封装的上传文件类

/* * 说明:文件上传类 * 作者:sgw * 时间:2018-7-31 */class Upload{  //成员属性  private $_maxsize    = 2*1024*1024;  //上传的文件最大范围2M  private $_upload_path  = 'upload/'; //上传的文件保存路径  private $_prefix     = 'odshen_';       //文件名的前缀  private $allow_type   = array('.jpg','.png','.gif','.jpeg');  //允许上传的文件类型  private $allow_mime_type = array('image/jpeg','image/png','image/gif','image/jpg');  /**   * set 设置私有的属性   * @param [str] $p [属性名]   * @param [mix] $v [给属性赋的值]   */  public function __set($p,$v)  {    if(property_exists($this,$p)){      $this -> $p = $v;    }  }  /**   * get 获取私有属性   * @param [str] $p [属性名]   */  public function __get($p)  {    if(property_exists($this,$p)){      return $this -> $p;    }  }  /**   * 上传文件方法   * @param [mix] $file [上传的文件]   */  public function doUpload($file)  {    //判断用户上传的文件大小    $max_size = $this->_maxsize;  //约束最大为2M    if($file['size'] > $max_size){      echo '上传文件过大,重新上传';      exit;    }    #防止上传的文件被覆盖    $prefix = $this->_prefix;    // 文件名唯一    $filename = uniqid($prefix,true);    //文件的后缀,从上传的文件名称中截取最后一个点后面的内容 strrchr    $ext = strrchr($file['name'],'.');    //分目录保存上传的文件,按照日期格式保存    $sub_path = $this->_upload_path.date('Ymd').'/';    // upload/20180731/    # 如果当前目录不存在,需要先创建 ,绝对路径    $now_path = __DIR__.'/';    $now_path = str_replace('//','/',$now_path.$sub_path);    if(!is_dir($now_path)){      mkdir($now_path,0777,true);    }    # 限制用户上传的文件类型    if(!in_array($ext,$this->allow_type)){      echo '文件类型不支持';      exit;    }    # 防止用户修改文件的后缀,借助php的一个扩展Finfo实现,精确获得每个文件在网络中的类型    $finfo = new Finfo(FILEINFO_MIME_TYPE);    $mime_type = $finfo -> file($file['tmp_name']);    if(!in_array($mime_type,$this->allow_mime_type)){      echo '文件类型不支持';      exit;    }    //参数1:待移动的文件(临时文件)    //参数2:目的地    //返回结果布尔类型    if(move_uploaded_file($file['tmp_name'],$now_path.$filename.$ext)){      //上传成功将上传的文件地址返回,便于在其他地方使用该图片,就需要能够找到该图片      return $sub_path . $filename.$ext;    }else{      //echo '上传失败';      return false;    }  }}            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表