<?php  
/**   
* 常用工具类 
* www.jb200.com
*/  
class Tool {  
/** 
 * js 弹窗并且跳转 
 * @param string $_info 
 * @param string $_url 
 * @return js 
 */  
static public function alertLocation($_info, $_url) {  
echo "<script type='text/
javascript'>alert('$_info');location.href='$_url';</script>";  
exit();  
}  
  
/** 
 * js 弹窗返回 
 * @param string $_info 
 * @return js 
 */  
static public function alertBack($_info) {  
echo "<script type='text/javascript'>alert('$_info');history.back();</script>";  
exit();  
}  
  
/** 
 * 
页面跳转 
 * @param string $url 
 * @return js 
 */  
static public function headerUrl($url) {  
echo "<script type='text/javascript'>location.href='{$url}';</script>";  
exit();  
}  
  
/** 
 * 弹窗关闭 
 * @param string $_info 
 * @return js 
 */  
static public function alertClose($_info) {  
echo "<script type='text/javascript'>alert('$_info');close();</script>";  
exit();  
}  
  
/** 
 * 弹窗 
 * @param string $_info 
 * @return js 
 */  
static public function alert($_info) {  
echo "<script type='text/javascript'>alert('$_info');</script>";  
exit();  
}  
  
/** 
 * 系统基本参数上传图片专用 
 * @param string $_path 
 * @return null 
 */  
static public function sysUploadImg($_path) {  
echo '<script type="text/javascript">document.getElementById("logo").value="'.$_path.'";</script>';  
echo '<script type="text/javascript">document.getElementById("pic").src="'.$_path.'";</script>';  
echo '<script type="text/javascript">$("#loginpop1").hide();</script>';  
echo '<script type="text/javascript">$("#bgloginpop2").hide();</script>';  
}  
  
/** 
 * 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);  
}  
}  
}  
clo
sedir($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;  
} // www.jb200.com
$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+1) {  
return '';  
}  
if($str_len < $startdd + $slen || $slen==0) {  
$slen = $str_len - $startdd;  
}  
$enddd = $startdd + $slen - 1;  
for($i=0;$i<$str_len;$i++) {  
if($startdd==0) {  
$restr .= $c;  
} elseif($i > $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) < $start+1) {  
return '';  
}  
preg_match_all("/./su", $str, $ar);  
$str = '';  
$tstr = '';  
//为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取  
for($i=0; isset($ar[0][$i]); $i++) {  
if(strlen($tstr) < $start) {  
$tstr .= $ar[0][$i];  
} else {  
if(strlen($str) < $length + strlen($ar[0][$i]) ) {  
$str .= $ar[0][$i];  
} else {  
break;  
}  
}  
}  
return $str;  
}  
  
/** 
 * 删除图片,根据图片ID 
 * @param int $image_id 
 */  
static function delPicByImageId($image_id) {  
$db_name = PREFIX . 'images i';  
$m = new Model();  
$data = $m->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($widthratio<$heightratio)  
$ratio = $widthratio;  
else  
$ratio = $heightratio;  
}  
if($resizewidth_tag && !$resizeheight_tag)  
$ratio = $widthratio;  
if($resizeheight_tag && !$resizewidth_tag)  
$ratio = $heightratio;  
$newwidth = $pic_width * $ratio;  
$newheight = $pic_height * $ratio;  
if(function_exists("imagecopyresampled")) {  
$newim = imagecreatetruecolor($newwidth,$newheight);  
imagecopyresampled($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height);  
} else {  
$newim = imagecreate($newwidth,$newheight);  
imagecopyresized($newim,$im,0,0,0,0,$newwidth,$newheight,$pic_width,$pic_height);  
}  
$name = $name.$filetype;  
imagejpeg($newim,$name);  
imagedestroy($newim);  
} else {  
$name = $name.$filetype;  
imagejpeg($im,$name);  
}  
}  
  
/** 
 * 下载文件 
 * @param string $file_path 
绝对路径 
 */  
static public function downFile($file_path) {  
//判断文件是否存在  
$file_path = 
iconv('utf-8', 'gb2312', $file_path); //对可能出现的中文名称进行转码  
if (!file_exists($file_path)) {  
exit('文件不存在!');  
}  
$file_name = basename($file_path); //获取文件名称  
$file_size = filesize($file_path); //获取文件大小  
$fp = fopen($file_path, 'r'); //以只读的方式打开文件  
header("Content-type: application/octet-stream");  
header("Accept-Ranges: bytes");  
header("Accept-Length: {$file_size}");  
header("Content-Disposition: attachment;filename={$file_name}");  
$buffer = 1024;  
$file_count = 0;  
//判断文件是否结束  
while (!feof($fp) && ($file_size-$file_count>0)) {  
$file_data = fread($fp, $buffer);  
$file_count += $buffer;  
echo $file_data;  
}  
fclose($fp); //关闭文件  
}  
}  
?>