PHP常用的类封装小结【4个工具类】
更新时间:2019年06月28日 11:38:27 作者:webbc
这篇文章主要介绍了PHP常用的类封装,结合实例形式分析了4个常用的工具类,包括Mysql类、分页类、缩略图类、上传类,需要的朋友可以参考下
本文实例讲述了PHP常用的类封装。分享给大家供大家参考,具体如下:
这4个类分别是Mysql类、 分页类、缩略图类、上传类。
Mysql类
<?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(); } } ?>
分页类
<?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; } } ?>
缩略图类
<?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); } } ?>
上传类
<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); } } } ?>
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php+mysql数据库操作入门教程》、《php+mysqli数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP网络编程技巧总结》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
相关文章
php提示Warning:mysql_fetch_array() expects的解决方法
这篇文章主要介绍了php提示Warning:mysql_fetch_array() expects的解决方法,是一个比较典型的php程序错误排查案例,具有一定的参考借鉴价值,需要的朋友可以参考下2014-12-12PHP简单选择排序(Simple Selection Sort)算法学习
这篇文章主要为大家详细介绍了PHP简单选择排序(Simple Selection Sort)算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-01-01
最新评论