<?PHP
/**
* 常用工具类
* author Lee.
* Last modify $Date: 2012-8-23
*/
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,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 $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,$width,$height);
//按坐标位置拷贝水印图片到真彩图像上
imagecopy($nimage,$src_im,$src_x,$src_y,$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);
}
}
/**
* @access public
* @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,$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;
}
/**
*
* @access public
* @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;
}
/**
* @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 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,$newwidth,$newheight,$pic_width,$pic_height);
} else {
$newim = imagecreate($newwidth,$newheight);
imagecopyresized($newim,$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;
}
}
}
?>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。