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

PHP效能集合类源码

程序员文章站 2024-01-25 17:51:46
...
PHP功能集合类源码

代码如下:

alert('$_info');location.href='$_url';";		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] = Tool::htmlString($_value);  //递归			}		} elseif (is_object($_date)) {			foreach ($_date as $_key=>$_value) {				$_string->$_key = Tool::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 Tool::mysqlString(trim($_POST[$param]));		} elseif ($type=='get') {			return Tool::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); //关闭文件	}}?>

?

PHP效能集合类源码

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

相关文章

相关视频


网友评论

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

我要评论
  • PHP效能集合类源码
  • 专题推荐