欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

最完整PHP惯用工具类大全

程序员文章站 2022-06-12 16:45:27
...
最完整PHP常用工具类大全
 0)); $i ++) {			if ($number = strpos ( str_pad ( decbin ( ord ( substr ( $string, $i, 1 ) ) ), 8, '0', STR_PAD_LEFT ), '0' )) {				if ($length SetLanguage('zh_cn');		$mailer->Host = Yii::app()->params['emailHost']; //发送邮件服务器		$mailer->Port = Yii::app()->params['emailPort']; //邮件端口		$mailer->Timeout = Yii::app()->params['emailTimeout'];//邮件发送超时时间		$mailer->ContentType = 'text/html';//设置html格式		$mailer->SMTPAuth = true;		$mailer->Username = Yii::app()->params['emailUserName'];		$mailer->Password = Yii::app()->params['emailPassword'];		$mailer->IsSMTP ();		$mailer->From = $mailer->Username; // 发件人邮箱		$mailer->FromName = Yii::app()->params['emailFormName']; // 发件人姓名		$mailer->AddReplyTo ( $mailer->Username );		$mailer->CharSet = 'UTF-8';		// 添加邮件日志		$modelMail = new MailLog ();		$modelMail->accept = $toemail;		$modelMail->subject = $subject;		$modelMail->message = $message;		$modelMail->send_status = 'waiting';		$modelMail->save ();		// 发送邮件		$mailer->AddAddress ( $toemail );		$mailer->Subject = $subject;		$mailer->Body = $message;		if ($mailer->Send () === true) {			$modelMail->times = $modelMail->times + 1;			$modelMail->send_status = 'success';			$modelMail->save ();			return true;		} else {			$error = $mailer->ErrorInfo;			$modelMail->times = $modelMail->times + 1;			$modelMail->send_status = 'failed';			$modelMail->error = $error;			$modelMail->save ();			return false;		}	}	/**	 * 判断字符串是utf-8 还是gb2312	 * @param unknown $str	 * @param string $default	 * @return string	 */	public static function utf8_gb2312($str, $default = 'gb2312')	{	    $str = preg_replace("/[\x01-\x7F]+/", "", $str);	    if (empty($str)) return $default;	    $preg =  array(	        "gb2312" => "/^([\xA1-\xF7][\xA0-\xFE])+$/", //正则判断是否是gb2312	        "utf-8" => "/^[\x{4E00}-\x{9FA5}]+$/u",      //正则判断是否是汉字(utf8编码的条件了),这个范围实际上已经包含了繁体中文字了	    );	    if ($default == 'gb2312') {	        $option = 'utf-8';	    } else {	        $option = 'gb2312';	    }	    if (!preg_match($preg[$default], $str)) {	        return $option;	    }	    $str = @iconv($default, $option, $str);	    //不能转成 $option, 说明原来的不是 $default	    if (empty($str)) {	        return $option;	    }	    return $default;	}	/**	 * utf-8和gb2312自动转化	 * @param unknown $string	 * @param string $outEncoding	 * @return unknown|string	 */	public static function safeEncoding($string,$outEncoding = 'UTF-8')	{		$encoding = "UTF-8";		for($i = 0; $i $v){			$ret[$k] = $v[$key];		}		return $ret;	}	/**	 * 判断 文件/目录 是否可写(取代系统自带的 is_writeable 函数)	 * @param string $file 文件/目录	 * @return boolean	 */	public static function is_writeable($file) {		if (is_dir($file)){			$dir = $file;			if ($fp = @fopen("$dir/test.txt", 'w')) {				@fclose($fp);				@unlink("$dir/test.txt");				$writeable = 1;			} else {				$writeable = 0;			}		} else {			if ($fp = @fopen($file, 'a+')) {				@fclose($fp);				$writeable = 1;			} else {				$writeable = 0;			}		}		return $writeable;	}	/**	 * 格式化单位	 */	static public function byteFormat( $size, $dec = 2 ) {		$a = array ( "B" , "KB" , "MB" , "GB" , "TB" , "PB" );		$pos = 0;		while ( $size >= 1024 ) {			$size /= 1024;			$pos ++;		}		return round( $size, $dec ) . " " . $a[$pos];	}	/**	 * 下拉框,单选按钮 自动选择	 *	 * @param $string 输入字符	 * @param $param  条件	 * @param $type   类型	 * selected checked	 * @return string	 */	static public function selected( $string, $param = 1, $type = 'select' ) {		$true = false;		if ( is_array( $param ) ) {			$true = in_array( $string, $param );		}elseif ( $string == $param ) {			$true = true;		}		$return='';		if ( $true )			$return = $type == 'select' ? 'selected="selected"' : 'checked="checked"';		echo $return;	}	/**	 * 下载远程图片	 * @param string $url 图片的绝对url	 * @param string $filepath 文件的完整路径(例如/www/images/test) ,此函数会自动根据图片url和http头信息确定图片的后缀名	 * @param string $filename 要保存的文件名(不含扩展名)	 * @return mixed 下载成功返回一个描述图片信息的数组,下载失败则返回false	 */	static public function downloadImage($url, $filepath, $filename) {		//服务器返回的头信息		$responseHeaders = array();		//原始图片名		$originalfilename = '';		//图片的后缀名		$ext = '';		$ch = curl_init($url);		//设置curl_exec返回的值包含Http头		curl_setopt($ch, CURLOPT_HEADER, 1);		//设置curl_exec返回的值包含Http内容		curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);		//设置抓取跳转(http 301,302)后的页面		curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);		//设置最多的HTTP重定向的数量		curl_setopt($ch, CURLOPT_MAXREDIRS, 3);		//服务器返回的数据(包括http头信息和内容)		$html = curl_exec($ch);		//获取此次抓取的相关信息		$httpinfo = curl_getinfo($ch);		curl_close($ch);		if ($html !== false) {			//分离response的header和body,由于服务器可能使用了302跳转,所以此处需要将字符串分离为 2+跳转次数 个子串			$httpArr = explode("\r\n\r\n", $html, 2 + $httpinfo['redirect_count']);			//倒数第二段是服务器最后一次response的http头			$header = $httpArr[count($httpArr) - 2];			//倒数第一段是服务器最后一次response的内容			$body = $httpArr[count($httpArr) - 1];			$header.="\r\n";			//获取最后一次response的header信息			preg_match_all('/([a-z0-9-_]+):\s*([^\r\n]+)\r\n/i', $header, $matches);			if (!empty($matches) && count($matches) == 3 && !empty($matches[1]) && !empty($matches[1])) {				for ($i = 0; $i  realpath($filepath), 'width' => $sizeinfo[0], 'height' => $sizeinfo[1], 'orginalfilename' => $originalfilename, 'filename' => pathinfo($filepath, PATHINFO_BASENAME));					}				}			}		}		return false;	}	/**	 * 查找ip是否在某个段位里面	 * @param string $ip 要查询的ip	 * @param $arrIP     禁止的ip	 * @return boolean	 */	public static function ipAccess($ip='0.0.0.0', $arrIP = array()){		$access = true;		$ip && $arr_cur_ip = explode('.', $ip);		foreach((array)$arrIP as $key=> $value){			if($value == '*.*.*.*'){				$access = false; //禁止所有				break;			}			$tmp_arr = explode('.', $value);			if(($arr_cur_ip[0] == $tmp_arr[0]) && ($arr_cur_ip[1] == $tmp_arr[1])) {				//前两段相同				if(($arr_cur_ip[2] == $tmp_arr[2]) || ($tmp_arr[2] == '*')){					//第三段为* 或者相同					if(($arr_cur_ip[3] == $tmp_arr[3]) || ($tmp_arr[3] == '*')){						//第四段为* 或者相同						$access = false; //在禁止ip列,则禁止访问						break;					}				}			}		}		return $access;	}	/**	 * @param string $string 原文或者密文	 * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE	 * @param string $key 密钥	 * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效	 * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文	 *	 * @example	 *	 * $a = authcode('abc', 'ENCODE', 'key');	 * $b = authcode($a, 'DECODE', 'key');  // $b(abc)	 *	 * $a = authcode('abc', 'ENCODE', 'key', 3600);	 * $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空	 */	public static function authcode($string, $operation = 'DECODE', $key = '', $expiry = 3600) {		$ckey_length = 4;		// 随机密钥长度 取值 0-32;		// 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。		// 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方		// 当此值为 0 时,则不产生随机密钥		$key = md5 ( $key ? $key : 'key' ); //这里可以填写默认key值		$keya = md5 ( substr ( $key, 0, 16 ) );		$keyb = md5 ( substr ( $key, 16, 16 ) );		$keyc = $ckey_length ? ($operation == 'DECODE' ? substr ( $string, 0, $ckey_length ) : substr ( md5 ( microtime () ), - $ckey_length )) : '';		$cryptkey = $keya . md5 ( $keya . $keyc );		$key_length = strlen ( $cryptkey );		$string = $operation == 'DECODE' ? base64_decode ( substr ( $string, $ckey_length ) ) : sprintf ( '%010d', $expiry ? $expiry + time () : 0 ) . substr ( md5 ( $string . $keyb ), 0, 16 ) . $string;		$string_length = strlen ( $string );		$result = '';		$box = range ( 0, 255 );		$rndkey = array ();		for($i = 0; $i  0) && substr ( $result, 10, 16 ) == substr ( md5 ( substr ( $result, 26 ) . $keyb ), 0, 16 )) {				return substr ( $result, 26 );			} else {				return '';			}		} else {			return $keyc . str_replace ( '=', '', base64_encode ( $result ) );		}	}	public static function gbkToUtf8($str){		return iconv("GBK", "UTF-8", $str);	}	/**	 * 取得输入目录所包含的所有目录和文件	 * 以关联数组形式返回	 * author: flynetcn	 */	static public function deepScanDir($dir)	{		$fileArr = array();		$dirArr = array();		$dir = rtrim($dir, '//');		if(is_dir($dir)){			$dirHandle = opendir($dir);			while(false !== ($fileName = readdir($dirHandle))){				$subFile = $dir . DIRECTORY_SEPARATOR . $fileName;				if(is_file($subFile)){					$fileArr[] = $subFile;				} elseif (is_dir($subFile) && str_replace('.', '', $fileName)!=''){					$dirArr[] = $subFile;					$arr = self::deepScanDir($subFile);					$dirArr = array_merge($dirArr, $arr['dir']);					$fileArr = array_merge($fileArr, $arr['file']);				}			}			closedir($dirHandle);		}		return array('dir'=>$dirArr, 'file'=>$fileArr);	}	/**	 * 取得输入目录所包含的所有文件	 * 以数组形式返回	 * author: flynetcn	 */	static public function get_dir_files($dir)	{		if (is_file($dir)) {			return array($dir);		}		$files = array();		if (is_dir($dir) && ($dir_p = opendir($dir))) {			$ds = DIRECTORY_SEPARATOR;			while (($filename = readdir($dir_p)) !== false) {				if ($filename=='.' || $filename=='..') { continue; }				$filetype = filetype($dir.$ds.$filename);				if ($filetype == 'dir') {					$files = array_merge($files, self::get_dir_files($dir.$ds.$filename));				} elseif ($filetype == 'file') {					$files[] = $dir.$ds.$filename;				}			}			closedir($dir_p);		}		return $files;	}	/**	 * 删除文件夹及其文件夹下所有文件	 */	public static function deldir($dir) {		//先删除目录下的文件:		$dh=opendir($dir);		while ($file=readdir($dh)) {			if($file!="." && $file!="..") {				$fullpath=$dir."/".$file;				if(!is_dir($fullpath)) {					unlink($fullpath);				} else {					self::deldir($fullpath);				}			}		}		closedir($dh);		//删除当前文件夹:		if(rmdir($dir)) {			return true;		} else {			return false;		}	}		/**		 * js 弹窗并且跳转		 * @param string $_info		 * @param string $_url		 * @return js		 */		static public function alertLocation($_info, $_url) {			echo "";			exit();		}		/**		 * js 弹窗返回		 * @param string $_info		 * @return js		 */		static public function alertBack($_info) {			echo "";			exit();		}		/**		 * 页面跳转		 * @param string $url		 * @return js		 */		static public function headerUrl($url) {			echo "";			exit();		}		/**		 * 弹窗关闭		 * @param string $_info		 * @return js		 */		static public function alertClose($_info) {			echo "";			exit();		}		/**		 * 弹窗		 * @param string $_info		 * @return js		 */		static public function alert($_info) {			echo "";			exit();		}		/**		 * 系统基本参数上传图片专用		 * @param string $_path		 * @return null		 */		static public function sysUploadImg($_path) {			echo '';			echo '';			echo '';			echo '';		}		/**		 * html过滤		 * @param array|object $_date		 * @return string		 */		static public function htmlString($_date) {			if (is_array($_date)) {				foreach ($_date as $_key=>$_value) {					$_string[$_key] = self::htmlString($_value);  //递归				}			} elseif (is_object($_date)) {				foreach ($_date as $_key=>$_value) {					$_string->$_key = self::htmlString($_value);  //递归				}			} else {				$_string = htmlspecialchars($_date);			}			return $_string;		}		/**		 * 数据库输入过滤		 * @param string $_data		 * @return string		 */		static public function mysqlString($_data) {			$_data = trim($_data);			return !GPC ? addcslashes($_data) : $_data;		}		/**		 * 清理session		 */		static public function unSession() {			if (session_start()) {				session_destroy();			}		}		/**		 * 验证是否为空		 * @param string $str		 * @param string $name		 * @return bool (true or false)		 */		static function validateEmpty($str, $name) {			if (empty($str)) {				self::alertBack('警告:' .$name . '不能为空!');			}		}		/**		 * 验证是否相同		 * @param string $str1		 * @param string $str2		 * @param string $alert		 * @return JS		 */		static function validateAll($str1, $str2, $alert) {			if ($str1 != $str2) self::alertBack('警告:' .$alert);		}		/**		 * 验证ID		 * @param Number $id		 * @return JS		 */		static function validateId($id) {			if (empty($id) || !is_numeric($id)) self::alertBack('警告:参数错误!');		}		/**		 * 格式化字符串		 * @param string $str		 * @return string		 */		static public function formatStr($str) {			$arr = array(' ', '	', '&', '@', '#', '%',  '\'', '"', '\\', '/', '.', ',', '$', '^', '*', '(', ')', '[', ']', '{', '}', '|', '~', '`', '?', '!', ';', ':', '-', '_', '+', '=');			foreach ($arr as $v) {				$str = str_replace($v, '', $str);			}			return $str;		}		/**		 * 格式化时间		 * @param int $time 时间戳		 * @return string		 */		static public function formatDate($time='default') {			$date = $time == 'default' ? date('Y-m-d H:i:s', time()) : date('Y-m-d H:i:s', $time);			return $date;		}		/**		 * 获得真实IP地址		 * @return string		 */		static public function realIp() {			static $realip = NULL;			if ($realip !== NULL) return $realip;			if (isset($_SERVER)) {				if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {					$arr = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);					foreach ($arr AS $ip) {						$ip = trim($ip);						if ($ip != 'unknown') {							$realip = $ip;							break;						}					}				} elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {					$realip = $_SERVER['HTTP_CLIENT_IP'];				} else {					if (isset($_SERVER['REMOTE_ADDR'])) {						$realip = $_SERVER['REMOTE_ADDR'];					} else {						$realip = '0.0.0.0';					}				}			} else {				if (getenv('HTTP_X_FORWARDED_FOR')) {					$realip = getenv('HTTP_X_FORWARDED_FOR');				} elseif (getenv('HTTP_CLIENT_IP')) {					$realip = getenv('HTTP_CLIENT_IP');				} else {					$realip = getenv('REMOTE_ADDR');				}			}			preg_match('/[\d\.]{7,15}/', $realip, $onlineip);			$realip = !empty($onlineip[0]) ? $onlineip[0] : '0.0.0.0';			return $realip;		}		/**		 * 加载 Smarty 模板		 * @param string $html		 * @return null;		 */		static public function display() {			global $tpl;$html = null;			$htmlArr = explode('/', $_SERVER[SCRIPT_NAME]);			$html = str_ireplace('.php', '.html', $htmlArr[count($htmlArr)-1]);			$dir = dirname($_SERVER[SCRIPT_NAME]);			$firstStr = substr($dir, 0, 1);			$endStr = substr($dir, strlen($dir)-1, 1);			if ($firstStr == '/' || $firstStr == '\\') $dir = substr($dir, 1);			if ($endStr != '/' || $endStr != '\\') $dir = $dir . '/';			$tpl->display($dir.$html);		}		/**		 * 创建目录		 * @param string $dir		 */		static public function createDir($dir) {			if (!is_dir($dir)) {				mkdir($dir, 0777);			}		}		/**		 * 创建文件(默认为空)		 * @param unknown_type $filename		 */		static public function createFile($filename) {			if (!is_file($filename)) touch($filename);		}		/**		 * 正确获取变量		 * @param string $param		 * @param string $type		 * @return string		 */		static public function getData($param, $type='post') {			$type = strtolower($type);			if ($type=='post') {				return self::mysqlString(trim($_POST[$param]));			} elseif ($type=='get') {				return self::mysqlString(trim($_GET[$param]));			}		}		/**		 * 删除文件		 * @param string $filename		 */		static public function delFile($filename) {			if (file_exists($filename)) unlink($filename);		}		/**		 * 删除目录		 * @param string $path		 */		static public function delDir($path) {			if (is_dir($path)) rmdir($path);		}		/**		 * 删除目录及地下的全部文件		 * @param string $dir		 * @return bool		 */		static public function delDirOfAll($dir) {			//先删除目录下的文件:			if (is_dir($dir)) {				$dh=opendir($dir);				while (!!$file=readdir($dh)) {					if($file!="." && $file!="..") {						$fullpath=$dir."/".$file;						if(!is_dir($fullpath)) {							unlink($fullpath);						} else {							self::delDirOfAll($fullpath);						}					}				}				closedir($dh);				//删除当前文件夹:				if(rmdir($dir)) {					return true;				} else {					return false;				}			}		}		/**		 * 验证登陆		 */		static public function validateLogin() {			if (empty($_SESSION['admin']['user'])) header('Location:/admin/');		}		/**		 * 给已经存在的图片添加水印		 * @param string $file_path		 * @return bool		 */		static public function addMark($file_path) {			if (file_exists($file_path) && file_exists(MARK)) {				//求出上传图片的名称后缀				$ext_name = strtolower(substr($file_path, strrpos($file_path, '.'), strlen($file_path)));				//$new_name='jzy_' . time() . rand(1000,9999) . $ext_name ;				$store_path = ROOT_PATH . UPDIR;				//求上传图片高宽				$imginfo = getimagesize($file_path);				$width = $imginfo[0];				$height = $imginfo[1];				//添加图片水印				switch($ext_name) {					case '.gif':						$dst_im = imagecreatefromgif($file_path);						break;					case '.jpg':						$dst_im = imagecreatefromjpeg($file_path);						break;					case '.png':						$dst_im = imagecreatefrompng($file_path);						break;				}				$src_im = imagecreatefrompng(MARK);				//求水印图片高宽				$src_imginfo = getimagesize(MARK);				$src_width = $src_imginfo[0];				$src_height = $src_imginfo[1];				//求出水印图片的实际生成位置				$src_x = $width - $src_width - 10;				$src_y = $height - $src_height - 10;				//新建一个真彩色图像				$nimage = imagecreatetruecolor($width, $height);				//拷贝上传图片到真彩图像				imagecopy($nimage, $dst_im, 0, 0, 0, 0, $width, $height);				//按坐标位置拷贝水印图片到真彩图像上				imagecopy($nimage, $src_im, $src_x, $src_y, 0, 0, $src_width, $src_height);				//分情况输出生成后的水印图片				switch($ext_name) {					case '.gif':						imagegif($nimage, $file_path);						break;					case '.jpg':						imagejpeg($nimage, $file_path);						break;					case '.png':						imagepng($nimage, $file_path);						break;				}				//释放资源				imagedestroy($dst_im);				imagedestroy($src_im);				unset($imginfo);				unset($src_imginfo);				//移动生成后的图片				@move_uploaded_file($file_path, ROOT_PATH.UPDIR . $file_path);			}		}		/**		 *  中文截取2,单字节截取模式		 * @access public		 * @param string $str  需要截取的字符串		 * @param int $slen  截取的长度		 * @param int $startdd  开始标记处		 * @return string		 */		static public function cn_substr($str, $slen, $startdd=0){			$cfg_soft_lang = PAGECHARSET;			if($cfg_soft_lang=='utf-8') {				return self::cn_substr_utf8($str, $slen, $startdd);			}			$restr = '';			$c = '';			$str_len = strlen($str);			if($str_len  $startdd) {					$restr .= $c;				}				if(ord($str[$i])>0x80) {					if($str_len>$i+1) {						$c = $str[$i].$str[$i+1];					}					$i++;				} else {					$c = $str[$i];				}				if($i >= $enddd) {					if(strlen($restr)+strlen($c)>$slen) {						break;					} else {						$restr .= $c;						break;					}				}			}			return $restr;		}		/**		 *  utf-8中文截取,单字节截取模式		 *		 * @access public		 * @param string $str 需要截取的字符串		 * @param int $slen 截取的长度		 * @param int $startdd 开始标记处		 * @return string		 */		static public function cn_substr_utf8($str, $length, $start=0) {			if(strlen($str) getOne($db_name, "i.id={$image_id}", "i.path as p, i.big_img as b, i.small_img as s");			foreach ($data as $v) {				@self::delFile(ROOT_PATH . $v['p']);				@self::delFile(ROOT_PATH . $v['b']);				@self::delFile(ROOT_PATH . $v['s']);			}			$m->del(PREFIX . 'images', "id={$image_id}");			unset($m);		}		/**		 * 图片等比例缩放		 * @param resource $im    新建图片资源(imagecreatefromjpeg/imagecreatefrompng/imagecreatefromgif)		 * @param int $maxwidth   生成图像宽		 * @param int $maxheight  生成图像高		 * @param string $name    生成图像名称		 * @param string $filetype文件类型(.jpg/.gif/.png)		 */		static public function resizeImage($im, $maxwidth, $maxheight, $name, $filetype) {			$pic_width = imagesx($im);			$pic_height = imagesy($im);			if(($maxwidth && $pic_width > $maxwidth) || ($maxheight && $pic_height > $maxheight)) {				if($maxwidth && $pic_width>$maxwidth) {					$widthratio = $maxwidth/$pic_width;					$resizewidth_tag = true;				}				if($maxheight && $pic_height>$maxheight) {					$heightratio = $maxheight/$pic_height;					$resizeheight_tag = true;				}				if($resizewidth_tag && $resizeheight_tag) {					if($widthratio0)) {				$file_data = fread($fp, $buffer);				$file_count += $buffer;				echo $file_data;			}			fclose($fp); //关闭文件		}	}

下载地址 http://www.shouce.ren/post/view/id/1700

最完整PHP惯用工具类大全

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频


网友评论

文明上网理性发言,请遵守 新闻评论服务协议

我要评论
  • 最完整PHP惯用工具类大全
  • 专题推荐