前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PHP常用的类封装小结【4个工具类】

PHP常用的类封装小结【4个工具类】

作者头像
砸漏
发布2020-10-20 11:48:45
6530
发布2020-10-20 11:48:45
举报
文章被收录于专栏:恩蓝脚本

本文实例讲述了PHP常用的类封装。分享给大家供大家参考,具体如下:

这4个类分别是Mysql类、 分页类、缩略图类、上传类。

Mysql类

代码语言:javascript
复制
<?php
/**
 * Mysql类
 */
class Mysql{
  private static $link = null;//数据库连接
  /**
   * 私有的构造方法
   */
  private function __construct(){}
  /**
   * 连接数据库
   * @return obj 资源对象
   */
  private static function conn(){
    if(self::$link === null){
      $cfg = require './config.php';
      self::$link = new Mysqli($cfg['host'],$cfg['user'],$cfg['pwd'],$cfg['db']);
      self::query("set names ".$cfg['charset']);//设置字符集
    }
    return self::$link;
  }
  /**
   * 执行一条sql语句
   * @param str $sql 查询语句
   * @return obj   结果集对象
   */
  public static function query($sql){
    return self::conn()- query($sql);
  }
  /**
   * 获取多行数据
   * @param str $sql 查询语句
   * @return arr   多行数据
   */
  public static function getAll($sql){
    $data = array();
    $res = self::query($sql);
    while($row = $res- fetch_assoc()){
      $data[] = $row;
    }
    return $data;
  }
  /**
   * 获取一行数据
   * @param str $row 查询语句
   * @return arr   单行数据
   */
  public static function getRow($row){
    $res = self::query($sql);
    return $res- fetch_assoc();
  }
  /**
   * 获取单个结果
   * @param str $sql 查询语句
   * @return str   单个结果
   */
  public static function getOne($sql){
    $res = self::query($sql);
    $data = $res- fetch_row();
    return $data[0];
  }
  /**
   * 插入/更新数据
   * @param str $table 表名
   * @param arr $data 插入/更新的数据
   * @param str $act  insert/update
   * @param str $where 更新条件
   * @return bool 插入/更新是否成功
   */
  public static function exec($table,$data,$act='insert',$where='0'){
    //插入操作
    if($act == 'insert'){
      $sql = 'insert into '.$table;
      $sql .= ' ('.implode(',',array_keys($data)).')';
      $sql .= " values ('".implode("','",array_values($data))."')";
    }else if($act == 'update'){
      $sql = 'update '.$table.' set ';
      foreach ($data as $k =  $v) {
        $sql .= $k.'='."'$v',";
      }
      $sql = rtrim($sql,',');
      $sql .= ' where 1 and '.$where;
    }
    return self::query($sql);
  }
  /**
   * 获取最近一次插入的主键值
   * @return int 主键
   */
  public static function getLastId(){
    return self::conn()- insert_id;
  }
  /**
   * 获取最近一次操作影响的行数
   * @return int 影响的行数
   */
  public static function getAffectedRows(){
    return self::conn()- affected_rows;
  }
  /**
   * 关闭数据库连接
   * @return bool 是否关闭
   */
  public static function close(){
    return self::conn()- close();
  }
}
? 

分页类

代码语言:javascript
复制
<?php
/**
 * 分页类
 * @author webbc
 */
class Page{
  private $num;//总的文章数
  private $cnt;//每页显示的文章数
  private $curr;//当前的页码数
  private $p = 'page';//分页参数名
  private $pageCnt = 5;//分栏总共显示的页数
  private $firstRow;//每页的第一行数据
  private $pageIndex = array();//分页信息
  /**
   * 构造函数
   * @param int $num 总的文章数
   * @param int $cnt 每页显示的文章数
   */
  public function __construct($num,$cnt=10){
    $this- num = $num;
    $this- cnt = $cnt;
    $this- curr = empty($_GET[$this- p]) ? 1 : intval($_GET[$this- p]);
    $this- curr = $this- curr   0 ? $this- curr : 1;
    $this- firstRow  = $this- cnt * ($this- curr - 1);
    $this- getPage();
  }
  /**
   * 分页方法
   */
  private function getPage(){
    $page = ceil($this- num / $this- cnt);//总的页数
    $left = max(1,$this- curr - floor($this- pageCnt/2));//计算最左边页码
    $right = min($left + $this- pageCnt - 1 ,$page);//计算最右边页码
    $left = max(1,$right - ($this- pageCnt - 1));//当前页码往右靠,需要重新计算左边页面的值
    for($i=$left;$i<=$right;$i++){
      if($i == 1){
        $index = '第1页';
      }else if($i == $page){
        $index = '最后一页';
      }else{
        $index = '第'.$i.'页';
      }
      $_GET['page'] = $i;
      $this- pageIndex[$index] = http_build_query($_GET);
    }
  }
  /**
   * 返回分页信息数据
   * @return [type] [description]
   */
  public function show(){
    return $this- pageIndex;
  }
}
? 

缩略图类

代码语言:javascript
复制
<?php
/**
* 缩略图类
* @author webbc
*/
class Thumb{
private $thumbWidth;//缩略图的宽
private $thumbHeight;//缩略图的高
private $thumbPath;//缩略图保存的路径
private $sourcePath;//原图的路径
private $sourceWidth;//原图的宽度
private $sourceHeight;//原图的高度
private $sourceType;//原图的图片类型
/**
* 构造函数
* @param str $sourcePath 原图的绝对路径
* @param integer $thumbWidth 缩略图的宽
* @param integer $thumbHeight 缩略图的高
*/
public function __construct($sourcePath,$thumbWidth=200,$thumbHeight=200){
//获取原图的绝对路径
$this- sourcePath = $sourcePath;
//获取缩略图的大小
$this- thumbWidth = $thumbWidth;
$this- thumbHeight = $thumbHeight;
$this- thumbPath = $this- getThumbPath();
//计算大图的大小
list($this- sourceWidth,$this- sourceHeight,$this- sourceType) = getimagesize($this- sourcePath);
}
/**
* 确定缩略图保存的路径
* @return [type] [description]
*/
private function getThumbPath(){
$ext = $this- getExt();
$filename = basename($this- sourcePath,'.'.$ext).'_thumb'.'.'.$ext;
return $thumbPath = __DIR__.'/'.$filename;
}
/**
* 获取原图的扩展名
* @return str 扩展名
*/
private function getExt(){
return pathinfo($this- sourcePath,PATHINFO_EXTENSION);
}
/**
* 检测原图的扩展名是否合法,并返回相应类型
* @return bool/str 原图的类型
*/
public function getType(){
$typeArr = array(
1 =  'gif',
2 =  'jpeg',
3 =  'png',
15 =  'wbmp'
);
if(!in_array($this- sourceType, array_keys($typeArr))){
return false;
}
return $typeArr[$this- sourceType];
}
/**
* 按照缩略图大小,计算大图的缩放比例
* @return float 缩放比例
*/
public function calculateRate(){
return min($this- thumbWidth / $this- sourceWidth,$this- thumbHeight / $this- sourceHeight);
}
/**
* 计算大图按照缩放比例后,最终的图像大小
* @param float $rate 缩放比例
* @return arr 缩放后的图片大小
*/
public function getImageSizeByRate($rate){
$width = $this- sourceWidth * $rate;
$height = $this- sourceHeight * $rate;
return array('w'= $width,'h'= $height);
}
/**
* 保存成文件
* @return [type] [description]
*/
public function saveFile($image){
$method = "image".$this- getType();
$method($image,$this- thumbPath);
}
/**
* 进行绘画操作
* @return [type] [description]
*/
public function draw(){
if(!($type = $this- getType())){
echo "文件类型不支持";
return ;
}
//创建大图和小图的画布
$method = "imagecreatefrom".$type;
$bigCanvas = $method($this- sourcePath);
$smallCanvas = imagecreatetruecolor($this- thumbWidth, $this- thumbHeight);
//创建白色画笔,并给小图画布填充背景
$white = imagecolorallocate($smallCanvas, 255, 255, 255);
imagefill($smallCanvas, 0, 0, $white);
//计算大图的缩放比例
$rate = $this- calculateRate();
//计算大图缩放后的大小信息
$info = $this- getImageSizeByRate($rate);
//进行缩放
imagecopyresampled($smallCanvas, $bigCanvas,
($this- thumbWidth - $info['w']) / 2 , ($this- thumbHeight - $info['h']) / 2,
0, 0, $info['w'], $info['h'], $this- sourceWidth, $this- sourceHeight);
//保存成文件
$this- saveFile($smallCanvas);
//销毁画布
imagedestroy($bigCanvas);
imagedestroy($smallCanvas);
}
}
? 

上传类

代码语言:javascript
复制
<meta charset="utf8"/ 
<?php
/**
* 文件上传类
* @author webbc
*/
class Upload{
private $allowExt = array('gif','jpg','jpeg','bmp','png','swf');//限制文件上传的后缀名
private $maxSize = 1;//限制最大文件上传1M
/**
* 获取文件的信息
* @param str $flag 上传文件的标识
* @return arr    上传文件的信息数组
*/
public function getInfo($flag){
return $_FILES[$flag];
}
/**
* 获取文件的扩展名
* @param str $filename 文件名
* @return str 文件扩展名
*/
public function getExt($filename){
return pathinfo($filename,PATHINFO_EXTENSION);
}
/**
* 检测文件扩展名是否合法
* @param str $filename 文件名
* @return bool 文件扩展名是否合法
*/
private function checkExt($filename){
$ext = $this- getExt($filename);
return in_array($ext,$this- allowExt);
}
/**
* 检测文件大小是否超过限制
* @param int size 文件大小
* @return bool 文件大小是否超过限制
*/
public function checkSize($size){
return $size < $this- maxSize * 1024 * 1024;
}
/**
* 随机的文件名
* @param int $len 随机文件名的长度
* @return str 随机字符串
*/
public function randName($len=6){
return substr(str_shuffle('abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ234565789'),0,$len);
}
/**
* 创建文件上传到的路径
* @return str 文件上传的路径
*/
public function createDir(){
$dir = './upload/'.date('Y/m/d',time());
if(is_dir($dir) || mkdir($dir,0777,true)){
return $dir;
}
}
/**
* 文件上传
* @param str $flag 文件上传标识
* @return arr 文件上传信息
*/
public function uploadFile($flag){
if($_FILES[$flag]['name'] === '' || $_FILES[$flag]['error'] !== 0){
echo "没有上传文件";
return;
}
$info = $this- getInfo($flag);
if(!$this- checkExt($info['name'])){
echo "不支持的文件类型";
return;
}
if(!$this- checkSize($info['size'])){
echo "文件大小超过限制";
return;
}
$filename = $this- randName().'.'.$this- getExt($info['name']);
$dir = $this- createDir();
if(!move_uploaded_file($info['tmp_name'], $dir.'/'.$filename)){
echo "文件上传失败";
}else{
return array('filename'= $filename,'dir'= $dir);
}
}
}
? 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档