文档章节

php常用工具类

魏邪乎
 魏邪乎
发布于 2015/04/15 12:09
字数 1682
阅读 671
收藏 11
<?php  
/**   
* 常用工具类   
* @author wj   
* @date   2015-4-15
*/  
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);  
                    }  
                }  
            }  
            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+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); //关闭文件  
    }  
}

© 著作权归作者所有

上一篇: ajax格式
魏邪乎
粉丝 6
博文 80
码字总数 21516
作品 0
保定
私信 提问
理解 PHP 中的 Streams

Streams 是PHP提供的一个强有力的工具,我们常常在不经意会使用到它,如果善加利用将大大提高PHP的生产力。 驾驭Streams的强大力量后,应用程序将提升到一个新的高度。 下面是PHP手册中对Str...

kisaya
2014/11/07
8.8K
28
phalcon系列(1) hello phalcon

接触和对比了了比较多的php框架,要说性能上,c类框架肯定比其他框架的性能要突出很多,就yaf跟phalcon而言,phalcon仅仅比yaf慢了1/10的性能,然而在组件上面却更加丰富。 Phalcon 是开源、...

hey_heihei
2018/02/27
90
0
一个PHP程序员应该掌握的10项技能

网站推广很多学PHP的人一直也搞不清楚,一个PHP程序员和Java程序员或者是.net程序员有什么不同,告诉你,其实都一样!没有什么不同,下面的内容,就是针对一个Java程序员掌握的技能对比PHP来说...

网络营销
2011/12/31
141
0
开源数据中心资产管理系统openDCIM 源程序理解

未命名 基础类 数据库类:db.inc.php 主要功能:数据库配置,初始化连接$dbh;引入、初始化配置类$config 配置类:config.inc.php 主要类:配置 工具类:facilities.inc.php 主要功能:引入a...

hillsdong
2014/02/19
1K
4
php程序员应该掌握的10个技能

1、语法:必须熟练掌握 ,写代码的时候IDE的编辑器对某一行报错应该能够根据报错信息知道是什么样的语法错误并且知道任何修正。 2、命令:必须熟悉PHP带的一些常用命令及其常用选项,熟悉那些...

忆童
2012/02/14
131
0

没有更多内容

加载失败,请刷新页面

加载更多

64.监控平台介绍 安装zabbix 忘记admin密码

19.1 Linux监控平台介绍 19.2 zabbix监控介绍 19.3/19.4/19.6 安装zabbix 19.5 忘记Admin密码如何做 19.1 Linux监控平台介绍: 常见开源监控软件 ~1.cacti、nagios、zabbix、smokeping、ope...

oschina130111
今天
13
0
当餐饮遇上大数据,嗯真香!

之前去开了一场会,主题是「餐饮领袖新零售峰会」。认真听完了餐饮前辈和新秀们的分享,觉得获益匪浅,把脑子里的核心纪要整理了一下,今天和大家做一个简单的分享,欢迎感兴趣的小伙伴一起交...

数澜科技
今天
7
0
DNS-over-HTTPS 的下一代是 DNS ON BLOCKCHAIN

本文作者:PETER LAI ,是 Diode 的区块链工程师。在进入软件开发领域之前,他主要是在做工商管理相关工作。Peter Lai 也是一位活跃的开源贡献者。目前,他正在与 Diode 团队一起开发基于区块...

红薯
今天
12
0
CC攻击带来的危害我们该如何防御?

随着网络的发展带给我们很多的便利,但是同时也带给我们一些网站安全问题,网络攻击就是常见的网站安全问题。其中作为站长最常见的就是CC攻击,CC攻击是网络攻击方式的一种,是一种比较常见的...

云漫网络Ruan
今天
12
0
实验分析性专业硕士提纲撰写要点

为什么您需要研究论文的提纲? 首先当您进行研究时,您需要聚集许多信息和想法,研究论文提纲可以较好地组织你的想法, 了解您研究资料的流畅度和程度。确保你写作时不会错过任何重要资料以此...

论文辅导员
今天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部