这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四个常用类封装的更多相关文章

  1. php四个常用类封装 :MySQL类、 分页类、缩略图类、上传类;;分页例子;

    Mysql类 <?php /** * Mysql类 */ class Mysql{ private static $link = null;//数据库连接 /** * 私有的构造方法 */ pr ...

  2. java总结第四次//常用类

    六.常用类 主要内容:Object类.String类.Date类.封装类 (一)Object类 1.Object类是所有Java类的根父类 2.如果在类的声明中未使用extends关键字指明其父类,则 ...

  3. Java基础常用类深度解析(包含常见排序算法)

    目录 一.工具类 1.1.工具类的设计 1.1.1.公共静态方法 1.2.单例模式 二.包装类 2.1.基本类型的包装类 2.1.1.Integer 2.1.1.1.Integer >> ...

  4. iOS常用动画 类封装

    //这是一个很好的动画封装类 很容易明白很详细 和大家分享 // CoreAnimationEffect.h // CoreAnimationEffect // // Created by Vince ...

  5. ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪

    ASP.NET MVC深入浅出(被替换)   一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...

  6. 第十四章 Java常用类

    14.常用类 14.1 字符串相关的类 1课时 14.2 JDK 8之前时间日期API 1课时 14.3 JDK8中新时间日期API 1课时 14.4 JDK8中的Optional类 1课时 14.5 ...

  7. 前端(十四)—— JavaScript常用类:Number、Date类、字符串、数组、Math类、正则

    JS常用类:Number类.Date类.Math类.字符串.数组.正则 一.Number 1.常用数字 整数:10 小数:3.14 科学计数法:1e5 | 1e-5 正负无穷:Infinity | - ...

  8. salesforce 零基础学习(四十八)自定义列表分页之Pagination基类封装 ※※※

    我们知道,salesforce中系统标准列表页面提供了相应的分页功能,如果要使用其分页功能,可以访问http://www.cnblogs.com/zero-zyq/p/5343287.html查看相关 ...

  9. 四、spring集成ibatis进行项目中dao层基类封装

    Apache iBatis(现已迁至Google Code下发展,更名为MyBatis)是当前IT项目中使用很广泛的一个半自动ORM框架,区别于Hibernate之类的全自动框架,iBatis对数据库 ...

随机推荐

  1. static之静态初始化块

    static之静态初始化块 所有的静态初始化块都优先执行,其次才是非静态的初始化块和构造函数,它们的执行顺序是:    父类的静态初始化块    子类的静态初始化块    父类的初始化块    父类的 ...

  2. python之函数第一篇

    一.为什么用函数: 解决代码重用问题 统一维护 程序的组织结构清晰,可读性强二.定义函数 先定义后使用!! def funcname(arg1,arg2,...): """ ...

  3. sencha touch 学习汇总(转)

    1.官方网站:http://www.sencha.com/products/touch/ 2.在线文档:http://docs.sencha.com/touch/2.2.1/ 3.在线翻译文档:htt ...

  4. Vue 开源项目库汇总(转)

    最近做了一个Vue开源项目库汇总,里面集合了OpenDigg 上的优质的Vue开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个star.https://gi ...

  5. JAVA自学笔记07

    JAVA自学笔记07 1.构造方法 1) 例如:Student s = new Student();//构造方法 System.out.println(s);// Student@e5bbd6 2)功 ...

  6. Hibernate关系映射时出现的问题

    在学习Hibernate框架的关系映射时,遇到了一个问题: INFO: HHH000422: Disabling contextual LOB creation as connection was n ...

  7. Win10系统的SurfacePro4的启动菜单太多怎么管理,UEFI的启动菜单如何编辑

    有时候多增加了一些硬盘版的PE,会出现下面这种问题,启动项目太多又删不掉(如果你硬盘版的PE修改了文件位置,这个选项还进不去)   关机之后,按开机键和音量+,进入Surface的启动菜单,直接删除原 ...

  8. 【ASP.NET Core】从向 Web API 提交纯文本内容谈起

    前些时日,老周在升级“华南闲肾回收登记平台”时,为了扩展业务,尤其是允许其他开发人员在其他平台向本系统提交有关肾的介绍资料,于是就为该系统增加了几个 Web API. 其中,有关肾的介绍采用纯文本方式 ...

  9. 【PMP】项目管理ITTO概述

    1.项目整合管理

  10. (整理)plsql导入dmp文件

    转载请注明出处: https://www.cnblogs.com/darkknightzh/p/10093063.html 参考网址: https://www.2cto.com/database/20 ...