本文实例讲述了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(){<a style="color:transparent">、本文来源gao($daima.com搞@代@#码$网</a><big>搞gaodaima代码</big> return $this->pageIndex; } } ?>