php表单和缩略图处理类是什么样呢

<?php
//封装一个表单验证类
//中文验证、邮箱验证、电话号码、手机、QQ、身份证、(由字母、数字、下划线组成,不能以数字开头)
header(‘content-type:text/html;charset=utf-8‘);
class Form{
/*
//中文验证的方法
//参数:$str,$num1,$num2
//返回值:匹配成功返回匹配的次数
*/
public function checkChina($str,$num1,$num2=‘‘){
//正则
$reg=‘/^[\x{4e00}-\x{9fa5}]{‘.$num1.‘,‘.$num2.‘}‘.‘$/u‘;
return preg_match($reg,$str);
}
/*
//邮箱验证
//参数:$email
//返回值: 匹配成功返回匹配的次数
*/
public function checkEmail($email){
//正则
$reg=‘/^\[email protected]\w+[.]com|cn|net$/‘;
return preg_match($reg,$email);
}
/*
//验证身份证
//参数 $card
//返回值: 匹配成功返回匹配的次数
*/
public function checkCard($card){
//正则
$reg=‘/^(\d{18}|\d{17}x)$/‘;
return preg_match($reg,$card);
}
/*
//要求输入内容由数字、字母、下划线组成,不能以数字开头,有位数限制
//参数:$str,$num1,$num2
//返回值: 匹配成功返回匹配的次数
*/
public function checkStr($str,$num1,$num2){
//正则
$reg=‘/^[a-zA-Z_]\w{‘.($num1-1).‘,‘.($num2-1).‘}$/‘;
return preg_match($reg,$str);
}
}

<?php
//图片处理工具类
class Image{
//属性
private $thumb_width; //缩略图的宽
private $thumb_height;
//错误属性
public $thumb_error;
//构造方法
public function __construct($width = 0,$height = 0){
$this->thumb_width = ($width == 0) ? $GLOBALS[‘config‘][‘admin_goods_thumb‘][‘width‘] : $width;
$this->thumb_height = ($height == 0) ? $GLOBALS[‘config‘][‘admin_goods_thumb‘][‘height‘] : $height;
}
/*
* 制作缩略图
* @param1 string $src,原图路径,/uploads/20150122101010abcdef.gif
* @param2 string $path,缩略图保存路径/uploads/thumb_20150122101010abcdef.gif
* @return 缩略图的名字
*/
public function makeThumb($src,$path){
//判断原图是否存在
if(!file_exists($src)){
$this->thumb_error = ‘原图不存在!‘;
return false;
}
//打开原图资源
//获取能够使用的后缀
$ext = $this->getFunctionName($src); //gif
//拼凑函数名
$open = ‘imagecreatefrom‘ . $ext; //imagecreatefromgif
$save = ‘image‘ . $ext; //imagegif
//如果不清楚;echo $open,$save;exit;
//可变函数打开原图资源
$src_img = $open($src); //利用可变函数打开图片资源
//imagecreatefromgif($src)
//缩略图资源
$dst_img = imagecreatetruecolor($this->thumb_width,$this->thumb_height);
//背景色填充白色
$dst_bg_color = imagecolorallocate($dst_img,255,255,255);
imagefill($dst_img,0,0,$dst_bg_color);
//宽高比确定宽高
$dst_size = $this->thumb_width / $this->thumb_height;
//获取原图数据
$file_info = getimagesize($src);
$src_size = $file_info[0]/$file_info[1];
//求出缩略图宽和高
if($src_size > $dst_size){
//原图宽高比大于缩略图
$width = $this->thumb_width;
$height = round($width / $src_size);
}else{
$height = $this->thumb_height;
$width = round($height * $src_size);
}
//求出缩略图起始位置
$dst_x = round($this->thumb_width - $width)/2;
$dst_y = round($this->thumb_height - $height)/2;
//制作缩略图
if(imagecopyresampled($dst_img,$src_img,$dst_x,$dst_y,0,0,$width,$height,$file_info[0],$file_info[1])){
//采样成功:保存,将文件保存到对应的路径下
$thumb_name = ‘thumb_‘ . basename($src);
$save($dst_img,$path . ‘/‘ . $thumb_name);
//保存成功
return $thumb_name;
}else{
//采样失败
$this->thumb_error = ‘缩略图采样失败!‘;
return false;
}
}
/*
* 获取文件要调用的函数名
* @param1 string $file,文件名字
* @return 通过文件后缀名得到的函数字符串
*/
private function getFunctionName($file){
//得到文件的后缀
$file_info = pathinfo($file);
$ext = $file_info[‘extension‘]; //后缀:gif,png,jpg,jpeg,pjpeg
//imagecreatefromgif,imagecreatefromjpeg,imagecreatefrompng
//定义一个数组保存函数名
$func = array(
‘gif‘ => ‘gif‘,
‘png‘ => ‘png‘,
‘jpg‘ => ‘jpeg‘,
‘jpeg‘ => ‘jpeg‘,
‘pjpeg‘ => ‘jpeg‘
);
//返回值
return $func[$ext];
}
}

时间: 2024-10-09 04:51:03

php表单和缩略图处理类是什么样呢的相关文章

js 验证表单 js提交验证类

js 验证表单 js提交验证类 附加:js验证radio是否选择 <script language="javascript">function checkform(obj){for(i=0;i<obj.oo.length;i++)         if(obj.oo[i].checked==true) return true; alert("请选择")return false; }</script><form id="f

Bootstrap快速学习笔记(2)表单系列之一

欢迎收看大奥编写的Bootstrap快速学习笔记(2)表单系列之一 本学习笔记根据[慕课网]教程修改而来,用它学习Bootstrap,将会带来全新的体验哦: .form-control类 水平表单 内联表单 详细介绍 form-control类把该类直接添加到控件上: 1.宽度变成了100%:2.设置了一个浅灰色(#ccc)的边框:3.具有4px的圆角:4.设置阴影效果,并且元素得到焦点之时,阴影和边框效果会有所变化:5.设置了placeholder的颜色为#999 水平表单最外层form标签要

JavaScript表单验证和正则表达式

JavaScript表单验证 分为四类: 1.非空验证 常用于用户名等 2.相等验证 常用于验证两次输入的密码 3.范围验证 常用于年龄等 4.正则验证 用于手机号,邮箱号等 以下是实例: 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html

Angular 表单

一. 模板表单 1. 如下图 2. code 3. 效果图 二.响应式表单 1. 增加ReactiveFormsModule 2.响应式表单用到的类和指令 3. 控制器代码 4. html <!--响应式表单--> <form [formGroup]="formModel" (submit)="submit()"> <input formControlName="username"> <div formG

纯CSS实现表单验证

ladies and 乡亲们,表单验证你在做吗?客户端or服务器端,javascript or jquery,动手写 or 使用插件,今天我们来探索下使用纯css实现表单验证,借以学习css selectors level 4中的表单相关的伪类选择器. 案例欣赏 代码我同样放到了codepen,大家可以在线研究,或下载收藏. 知识解析 关键在于使用css selectors levle4里的一些伪类实现表单验证,这些伪类有: :required和:optional :in-range和out-o

moodle中文API之表单API

Form API 表单API 目录 1.概述 2.亮点 3.用法 4.表单元素 4.1 基本表单元素 4.2 定制表单元素 5.常用函数 5.1  add_action_buttons($cancel =true,$submitlabel =null) 5.2 setDefault() 5.3 disableif() 5.4 addRule() 5.5 setHelpButton 5.6 addHelpButton 5.7 setType() 5.8 disable_form_change_ch

AngularJS 的表单验证

最近开始学习angularjs,学到表单验证的时候发现有必要学习下大神的好文章: 转:http://www.oschina.net/translate/angularjs-form-validation 今天我们将来看看Angular如何帮助做表单验证. 我们将讨论更多使用angular进行有关表单操作的东西(就像我们另外的一篇文章: 提交Ajax表单:AngularJS的方式). 不过不用担心,那篇文章不一定要读的. 我们将重点放在客户端验证上,并使用Angular内置的表单属性.这里有一个 

yii2表单,用惯yii1的可以看一下,有很大不同哦

使用表单 本章节将介绍如何创建一个从用户那搜集数据的表单页.该页将显示一个包含 name 输入框和 email 输入框的表单.当搜集完这两部分信息后,页面将会显示用户输入的信息. 为了实现这个目标,除了创建一个[操作]和两个[视图]外,还需要创建一个[模型]. 贯穿整个小节,你将会学到: * 创建一个[模型](structure-models.md)代表用户通过表单输入的数据* 声明规则去验证输入的数据* 在[视图](structure-views.md)中生成一个 HTML 表单 创建模型 ?

yii2的form表单用法

使用表单 本章节将介绍如何创建一个从用户那搜集数据的表单页.该页将显示一个包含 name 输入框和 email 输入框的表单.当搜集完这两部分信息后,页面将会显示用户输入的信息. 为了实现这个目标,除了创建一个[操作]和两个[视图]外,还需要创建一个[模型]. 贯穿整个小节,你将会学到: * 创建一个[模型](structure-models.md)代表用户通过表单输入的数据* 声明规则去验证输入的数据* 在[视图](structure-views.md)中生成一个 HTML 表单 创建模型 ?