• 技术文章 >后端开发 >php教程

    分享自定义的几个PHP功能函数

    PHP中文网PHP中文网2016-07-13 09:57:06原创289
    这篇文章主要介绍了分享自定义的几个PHP功能函数,本文罗列的都是WEB开发中常用的一些功能函数,例如提交过滤、字符串截取、IP地址匿名化、隐藏文件真实路径等,需要的朋友可以参考下

    最近不是在折腾论坛嘛,各种类各种函数,原创一些,从别人那儿qiang过来一些,在此分享出来,希望有朋友能用的到~

    注意:部分函数可能不够完善,由此造成的漏洞风险自担~

    提交过滤

    function filter($text)
    {
     //完全过滤注释
     $text = preg_replace('/<!--?.*-->/', '', $text);
     //完全过滤js
     $text = preg_replace('/<script?.*\/script>/', '', $text);
     //过滤危险的属性,如:过滤on事件lang js
     while (preg_match('/(<[^><]+)( lang|action|background|codebase|dynsrc|lowsrc)[^><]+/i', $text, $mat)) {
     $text = str_replace($mat[0], $mat[1], $text);
     }
     while (preg_match('/(<[^><]+)(window\.|javascript:|js:|about:|file:|document\.|vbs:|cookie)([^><]*)/i', $text, $mat)) {
     $text = str_replace($mat[0], $mat[1] . $mat[3], $text);
     }
     //过滤多余html
     $text = preg_replace('/<\/?(html|head|meta|link|base|basefont|body|bgsound|script|form|iframe|frame|frameset|applet|id|ilayer|layer|name|script|xml)[^><]*>/i', '', $text);
     //反转换
     $text = str_replace('[', '<', $text);
     $text = str_replace(']', '>', $text);
     $text = str_replace('|', '"', $text);
     return $text;
    }

    提交过滤2

    function stripslashes_array(&$array)
    {
     while (list($key, $var) = each($array)) {
     if ($key != 'argc' && $key != 'argv' && (strtoupper($key) != $key || '' . intval($key) == "$key")) {
     if (is_string($var)) {
     $array[$key] = stripslashes($var);
     }
     if (is_array($var)) {
     $array[$key] = stripslashes_array($var);
     }
     }
     }
     return $array;
    }

    字符串截取(这个是emlog里提出来的,其实也就是substr的增强版)

    function subString($strings, $start, $length)
    {
     if (function_exists('mb_substr') && function_exists('mb_strlen')) {
     $sub_str = mb_substr($strings, $start, $length, 'utf8');
     return mb_strlen($sub_str, 'utf8') < mb_strlen($strings, 'utf8') ? $sub_str . '...' : $sub_str;
     }
     $str = substr($strings, $start, $length);
     $char = 0;
     for ($i = 0; $i < strlen($str); $i++) {
     if (ord($str[$i]) >= 128)
     $char++;
     }
     $str2 = substr($strings, $start, $length + 1);
     $str3 = substr($strings, $start, $length + 2);
     if ($char % 3 == 1) {
     if ($length <= strlen($strings)) {
     $str3 = $str3 .= '...';
     }
     return $str3;
     }
     if ($char % 3 == 2) {
     if ($length <= strlen($strings)) {
     $str2 = $str2 .= '...';
     }
     return $str2;
     }
     if ($char % 3 == 0) {
     if ($length <= strlen($strings)) {
     $str = $str .= '...';
     }
     return $str;
     }
    }

    IP地址匿名化(最后一位替换为星号)

    function AnonymousIP() 
    {
     $ip = GetIP();
     if ($ip == "Unknown") {
     $removed_ip = "未知用户";
     }
     if (strpos($ip, ":")) {
     $removed_ip = "IPv6用户";
     } else {
     $reg1 = '/((?:\d+\.){3})\d+/';
     $reg2 = '~(\d+)\.(\d+)\.(\d+)\.(\d+)~';
     $removed_ip = preg_replace($reg1, "\\1*", $ip);
     }
     return $removed_ip;
    }

    获取客户端IP地址

    function GetIP()
    {
     if (@$_SERVER["HTTP_X_FORWARDED_FOR"])
     $ip = $_SERVER["HTTP_X_FORWARDED_FOR"];
     else if (@$_SERVER["HTTP_CLIENT_IP"])
     $ip = $_SERVER["HTTP_CLIENT_IP"];
     else if (@$_SERVER["REMOTE_ADDR"])
     $ip = $_SERVER["REMOTE_ADDR"];
     else if (@getenv("HTTP_X_FORWARDED_FOR"))
     $ip = getenv("HTTP_X_FORWARDED_FOR");
     else if (@getenv("HTTP_CLIENT_IP"))
     $ip = getenv("HTTP_CLIENT_IP");
     else if (@getenv("REMOTE_ADDR"))
     $ip = getenv("REMOTE_ADDR");
     else
     $ip = "Unknown";
     return $ip;
    }

    字符串加密(支持中文)

    function dencrypt($string, $isEncrypt = true, $key = "youdian")
    {
     if (!isset($string{0}) || !isset($key{0})) {
     return false;
     }
     
     $dynKey = $isEncrypt ? hash('sha1', microtime(true)) : substr($string, 0, 40);
     $fixedKey = hash('sha1', $key);
     
     $dynKeyPart1 = substr($dynKey, 0, 20);
     $dynKeyPart2 = substr($dynKey, 20);
     $fixedKeyPart1 = substr($fixedKey, 0, 20);
     $fixedKeyPart2 = substr($fixedKey, 20);
     $key = hash('sha1', $dynKeyPart1 . $fixedKeyPart1 . $dynKeyPart2 . $fixedKeyPart2);
     
     $string = $isEncrypt ? $fixedKeyPart1 . $string . $dynKeyPart2 : (isset($string{339}) ? gzuncompress(base64_decode(substr($string, 40))) : base64_decode(substr($string, 40)));
     
     $n = 0;
     $result = '';
     $len = strlen($string);
     
     for ($n = 0; $n < $len; $n++) {
     $result .= chr(ord($string{$n}) ^ ord($key{$n % 40}));
     }
     return $isEncrypt ? $dynKey . str_replace('=', '', base64_encode($n > 299 ? gzcompress($result) : $result)) : substr($result, 20, -20);
    }

    检查字符串是否包含中文

    function CheckChinese($string)
    {
     if (preg_match("/[\x7f-\xff]/", $string)) {
     return true;
     } else {
     return false;
     }
    }

    隐藏文件真实路径

    function FileHeaderJump($file)
    {
     header('Content-Description: File Transfer');
     header('Content-Type: application/octet-stream');
     header('Content-Disposition: attachment; filename=' . basename($file));
     header('Content-Transfer-Encoding: binary');
     header('Expires: 0');
     header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
     header('Pragma: public');
     header('Content-Length: ' . filesize($file));
     ob_clean();
     flush();
     readfile($file);
     exit;
    }

    生成随机字符串,自定义长度

    function CreateRandomString($length)
    {
     $chars = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
     $password = "";
     for ($i = 0; $i < $length; $i++) {
     $password .= $chars[mt_rand(0, strlen($chars) - 1)];
     }
     return $password;
    }
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:PHP 功能函数
    上一篇:基于php的微信公众平台开发入门实例,php公众平台实例_PHP教程 下一篇:PHP中trim()函数简单使用指南_PHP教程
    php培训_php实战培训【立即报名】-php中文网第20期

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 分享一个有趣的php版本的扫雷!• PHP框架开发1(首言) • 送给和小弟我一样曾经浮躁过的PHPer程序猿,希望有帮助 • Ubuntu中PhpMyAdmin装配说明 • php+js倒计时代码 秒不动解决思路
    1/1

    PHP中文网