0

0

我常用的common function库

php中文网

php中文网

发布时间:2016-07-25 09:09:14

|

702人浏览过

|

来源于php中文网

原创

有零填充、截取中文、halt、html跳转、js跳转、过滤html、检查邮箱合法、转换文字中的超链接为可点击连接、返回时间格式等等常用php函数库。

  1. //因为前后台都要用到,所以放在supermario文件夹下方便重用
  2. /**
  3. * 喔~可爱滴小数点~喔~可爱滴千位数~
  4. * 如果位数超过4位,则将第3位前增加,
  5. * @param int $gold
  6. * @return string
  7. */
  8. function showGold($gold) {
  9. return number_format($gold);
  10. }
  11. /**
  12. * 页面压缩输出
  13. */
  14. function ob_callback($buffer) {
  15. header('Etag: '.md5($buffer));
  16. if( extension_loaded('zlib') AND strstr($_SERVER["HTTP_ACCEPT_ENCODING"],"gzip") ) {
  17. $buffer = gzencode($buffer,9);
  18. header('Content-Encoding: gzip');
  19. header('Vary: Accept-Encoding');
  20. //header('Via: www.guangxitravel.cn');
  21. header('Content-Length: '.strlen($buffer));
  22. }
  23. return $buffer;
  24. }
  25. /**
  26. * 没有提示的情况下跳转页面
  27. * @param string $url
  28. * @param string $target
  29. */
  30. function go($url='', $target='parent') {
  31. if ($url != "") {
  32. echo('<script language="javascript">window.location="' . $url . '";</script>');
  33. } else {
  34. echo('<script language="javascript">window.location=self.location;"</script>');
  35. }
  36. }
  37. /**
  38. * 清除缓存,ECHO,然后DIE(可恶的javascript+php……纯文本输出,总会有一些空字符……)
  39. * @param string $msg
  40. */
  41. function justSay($msg) {
  42. ob_clean();
  43. die($msg);
  44. }
  45. /**
  46. * 将符合第二个参数的第一个参数里的内容替换为红色
  47. * @param string $data
  48. * @param array $keyword
  49. * @return string
  50. */
  51. function change_keyword($data, $keywords) {
  52. if (is_array($keywords)) {
  53. foreach ($keywords as $k => $v) {
  54. $data = str_replace($v, '' . $v . '', $data);
  55. }
  56. return $data;
  57. } else {
  58. return str_replace($keywords, '' . $keywords . '', $data);
  59. }
  60. }
  61. /**
  62. * 创建完全随机的颜色
  63. * @return string
  64. */
  65. function makeColor() {
  66. $key = '#';
  67. for ($i = 0; $i
  68. $key.= rand(0, 9);//生成php随机数
  69. return $key;
  70. }
  71. /**
  72. * 自动加载模型和第三方功能类
  73. * @param string $className
  74. */
  75. function autoLoad($className) {
  76. if (strstr($_SERVER['REQUEST_URI'], "/operator/") == false) { //服务器不支持SCRIPT_URL
  77. if (file_exists(siteRoot . '/client/model/' . $className . '.php')) {
  78. require_once siteRoot . '/client/model/' . $className . '.php';
  79. return;
  80. }
  81. } else {
  82. if (file_exists(siteRoot . '/manager/model/' . $className . '.php')) {
  83. require_once siteRoot . '/manager/model/' . $className . '.php';
  84. return;
  85. }
  86. }
  87. if (file_exists(siteRoot . '/public/modules/' . $className . '.php')) {
  88. require_once siteRoot . '/public/modules/' . $className . '.php';
  89. return;
  90. }
  91. if (file_exists(siteRoot . '/client/order/model/' . $className . '.php')) {
  92. require_once siteRoot . '/client/order/model/' . $className . '.php';
  93. return;
  94. }
  95. }
  96. /**
  97. * 用javascript弹出一条信息
  98. * @param $message
  99. */
  100. function message($message='') {
  101. echo('<script language="javascript">alert("' . $message . '");</script>');
  102. }
  103. /**
  104. * 模拟strstr()的第三个参数,返回$h中,$n之前的数据
  105. * //$h = haystack, $n = needle
  106. * @param $h
  107. * @param $n
  108. * @return
  109. */
  110. function strstrb($h, $n) {
  111. return array_shift(explode($n, $h, 2));
  112. }
  113. /**
  114. * 显示错误信息,并跳转至$pageurl,含有样式
  115. *
  116. * @param string $messages
  117. * @param string $pageurl
  118. * @param int $msc 秒数
  119. */
  120. function msg($messages, $pageurl='javascript:history.back();', $msc=5) {
  121. echo 'System Message
  122. *{margin:0;padding:0px}
  123. body{background:#fff;color:#333;font:12px Verdana, Tahoma, sans-serif;text-align:center;margin:0 auto;}
  124. a{text-decoration:none;color:#29458C}
  125. a:hover{text-decoration:underline;color:#f90}
  126. #msg{border:1px solid #c5d7ef;text-align:left;margin:10% auto; width:50%}
  127. #msgtitle{padding:5px 10px;background:#f0f6fb;border-bottom:1px #c5d7ef solid}
  128. #msgtitle h1{font-size:14px;font-weight:bold;padding-left:10px;border-left:3px solid #acb4be;color:#1f3a87}
  129. #msgcontent {padding:20px 50px;}
  130. #msgcontent li{display:block;padding:5px;list-style:none;}
  131. #msgcontent p{text-align:center;margin-top:10px;padding:0}
  132. Web System Message

  • ', $messages, '
  • >>>请点此处返回

  • ';
  • exit();
  • }
  • /**
  • * 检查后面的日期是否大于前面的日期
  • * @param type $datecome 前面的日期
  • * @param type $datego 后面的日期
  • * @return type
  • */
  • function sub_date($datecome, $datego) {
  • $d1 = strtotime($datecome);
  • $d2 = strtotime($datego);
  • $days = round(($d2 - $d1) / 3600 / 24);
  • $days = $days
  • return $days;
  • }
  • /**
  • * 将$string的$length后边的内容用$dot替换
  • * @param string $string
  • * @param int $length
  • * @param string $dot
  • * @return string
  • */
  • function cutstr($string, $length, $dot = '...') {
  • @extract($string);
  • if (strlen($string)
  • return $string;
  • }
  • $string = htmlspecialchars($string);
  • $string = str_replace(array('&', '"', ''), array('&', '"', ''), $string);
  • $strcut = '';
  • $n = $tn = $noc = 0;
  • while ($n
  • $t = ord($string[$n]);
  • if ($t == 9 || $t == 10 || (32
  • $tn = 1;
  • $n++;
  • $noc++;
  • } elseif (194
  • $tn = 2;
  • $n += 2;
  • $noc += 2;
  • } elseif (224
  • $tn = 3;
  • $n += 3;
  • $noc += 2;
  • } elseif (240
  • $tn = 4;
  • $n += 4;
  • $noc += 2;
  • } elseif (248
  • $tn = 5;
  • $n += 5;
  • $noc += 2;
  • } elseif ($t == 252 || $t == 253) {
  • $tn = 6;
  • $n += 6;
  • $noc += 2;
  • } else {
  • $n++;
  • }
  • if ($noc >= $length) {
  • break;
  • }
  • }
  • if ($noc > $length) {
  • $n -= $tn;
  • }
  • $strcut = substr($string, 0, $n);
  • $strcut = str_replace(array('&', '"', ''), array('&', '"', ''), $strcut);
  • return $strcut . $dot;
  • }
  • /**
  • +----------------------------------------------------------
  • * 如果 magic_quotes_gpc 为开启状态,则使用此方法使用为特殊符号前增加转移符号
  • +----------------------------------------------------------
  • * @access public
  • +----------------------------------------------------------
  • * @param string $value 可以为数组
  • +----------------------------------------------------------
  • * @return string
  • +----------------------------------------------------------
  • */
  • function kaddslashes($value) {
  • return $value = is_array($value) ? array_map('kaddslashes', $value) : addslashes($value);
  • }
  • /**
  • +----------------------------------------------------------
  • * 为特殊符号前去除转移符号
  • +----------------------------------------------------------
  • * @access public
  • +----------------------------------------------------------
  • * @param string $value 可以为数组
  • +----------------------------------------------------------
  • * @return string
  • +----------------------------------------------------------
  • */
  • function kstripcslashes($value) {
  • return $value = is_array($value) ? array_map('kstripcslashes', $value) : stripcslashes($value);
  • }
  • /**
  • * 将字符串内容html实体化,避免一些非法信息直接执行。如果参数是数组,则递归。
  • * @param string $value
  • * @return array
  • */
  • function khtmlspecialchars($value) {
  • return is_array($value) ? array_map('khtmlspecialchars', $value) :
  • preg_replace('/&((#(d{3,5}|x[a-fA-F0-9]{4})|[a-zA-Z][a-z0-9]{2,5});)/', '&\1', str_replace(array('&', '"', ''), array('&', '"', ''), $value));
  • }
  • /**
  • * 将字符串中的html去除,如果参数是数组,则递归。
  • * @param string $value
  • * @return array
  • */
  • function striptags($value) {
  • return $value = is_array($value) ? array_map('striptags', $value) : strip_tags($value);
  • }
  • /**
  • * 检查email的合法性
  • *
  • * @param string $email
  • * @return bool
  • */
  • function check_email($email) {
  • if (preg_match("/([a-z0-9]*[-_.]?[a-z0-9]+)*@([a-z0-9]*[-_]?[a-z0-9]+)+[.][a-z]{2,3}([.][a-z]{2})?/i", $email)) {
  • return true;
  • } else {
  • return false;
  • }
  • }
  • /**
  • * 安全电子邮件地址
  • *
  • * @param string $email
  • * @param string $title
  • * @param $attributes
  • * @return
  • */
  • function safe_mailto($email, $title = '', $attributes = '') {
  • if (is_array($email)) {
  • $tmp = $email;
  • unset($email);
  • extract($tmp);
  • }
  • $title = (string) $title;
  • if ($title == "") {
  • $title = $email;
  • }
  • for ($i = 0; $i
  • $x[] = substr('
  • }
  • $x[] = '"';
  • if ($attributes != '') {
  • if (is_array($attributes)) {
  • foreach ($attributes as $key => $val) {
  • $x[] = ' ' . $key . '="';
  • for ($i = 0; $i
  • $x[] = "|" . ord(substr($val, $i, 1));
  • }
  • $x[] = '"';
  • }
  • } else {
  • for ($i = 0; $i
  • $x[] = substr($attributes, $i, 1);
  • }
  • }
  • }
  • $x[] = '>';
  • $temp = array();
  • for ($i = 0; $i
  • $ordinal = ord($title[$i]);
  • if ($ordinal
  • $x[] = "|" . $ordinal;
  • } else {
  • if (count($temp) == 0) {
  • $count = ($ordinal
  • }
  • $temp[] = $ordinal;
  • if (count($temp) == $count) {
  • $number = ($count == 3) ? (($temp['0'] % 16) * 4096) + (($temp['1'] % 64) * 64) + ($temp['2'] % 64) : (($temp['0'] % 32) * 64) + ($temp['1'] % 64);
  • $x[] = "|" . $number;
  • $count = 1;
  • $temp = array();
  • }
  • }
  • }
  • $x[] = '
  • $x[] = '/';
  • $x[] = 'a';
  • $x[] = '>';
  • $x = array_reverse($x);
  • ob_start();
  • ?><script type="text/javascript"></script>
  • //
  • var l=new Array();
  • $i = 0;
  • foreach ($x as $val) {
  • ?>l[]='';
  • for (var i = l.length-1; i >= 0; i=i-1){
  • if (l[i].substring(0, 1) == '|') document.write(""+unescape(l[i].substring(1))+";");
  • else document.write(unescape(l[i]));}
  • //]]>
  • $buffer = ob_get_contents();
  • ob_end_clean();
  • if ($tmp == '' || $tmp == NULL) {
  • return $buffer;
  • } else {
  • echo $buffer;
  • }
  • }
  • /**
  • +----------------------------------------------------------
  • * 转换文字中的超链接为可点击连接
  • +----------------------------------------------------------
  • * @access public
  • +----------------------------------------------------------
  • * @param string $text 要处理的字符串
  • +----------------------------------------------------------
  • * @return string
  • +----------------------------------------------------------
  • */
  • function makeLink($string) {
  • $validChars = "a-z0-9/-_+=.~!%@?#&;:$|";
  • $patterns = array(
  • "/(^|[^]_a-z0-9-="'/])([a-z]+?)://([{$validChars}]+)/ei",
  • "/(^|[^]_a-z0-9-="'/])www.([a-z0-9-]+).([{$validChars}]+)/ei",
  • "/(^|[^]_a-z0-9-="'/])ftp.([a-z0-9-]+).([{$validChars}]+)/ei",
  • "/(^|[^]_a-z0-9-="'/:.])([a-z0-9-_.]+?)@([{$validChars}]+)/ei");
  • $replacements = array(
  • "'\1\2://'.Input::truncate( '\3' ).''",
  • "'\1'.Input::truncate( 'www.\2.\3' ).''",
  • "'\1'.Input::truncate( 'ftp.\2.\3' ).''",
  • "'\1'.Input::truncate( '\2@\3' ).''");
  • return preg_replace($patterns, $replacements, $string);
  • }
  • /**
  • * 获取客户端浏览器
  • * @return string
  • */
  • function browse_info() {
  • $browser = "";
  • $browserver = "";
  • $Browsers = array("Lynx", "MOSAIC", "AOL", "Opera", "JAVA", "MacWeb", "WebExplorer", "OmniWeb");
  • $Agent = $_SERVER["HTTP_USER_AGENT"]; //浏览器的全局变量
  • for ($i = 0; $i
  • if (strpos($Agent, $Browsers[$i])) {
  • $browser = $Browsers[$i];
  • $browserver = "";
  • }
  • }
  • if (ereg("Mozilla", $Agent) && ereg("MSIE", $Agent)) {
  • $temp = explode("(", $Agent);
  • $Part = $temp[1];
  • $temp = explode(";", $Part);
  • $Part = $temp[1];
  • $temp = explode(" ", $Part);
  • $browserver = $temp[2];
  • //$browserver =preg_replace("/([d.]+)/","1",$browserver);
  • $browserver = "IE" . $browserver;
  • $browser = "IE";
  • }
  • if (ereg("Mozilla", $Agent) && !ereg("MSIE", $Agent)) {
  • $temp = explode("(", $Agent);
  • $Part = $temp[0];
  • $temp = explode("/", $Part);
  • $browserver = $temp[1];
  • $temp = explode(" ", $browserver);
  • $browserver = $temp[0];
  • $browserver = preg_replace("/([d.]+)/", "1", $browserver);
  • $browserver = " $browserver";
  • $browser = "Netscape Navigator";
  • }
  • if (ereg("Mozilla", $Agent) && ereg("Opera", $Agent)) {
  • $temp = explode("(", $Agent);
  • $Part = $temp[1];
  • $temp = explode(")", $Part);
  • $browserver = $temp[1];
  • $temp = explode(" ", $browserver);
  • $browserver = $temp[2];
  • $browserver = preg_replace("/([d.]+)/", "1", $browserver);
  • $browserver = " $browserver";
  • $browser = "Opera";
  • }
  • //火狐浏览器
  • if (ereg("Mozilla", $Agent) && ereg("Firefox", $Agent)) {
  • $temp = explode("(", $Agent);
  • $Part = $temp[1];
  • $temp = explode(")", $Part);
  • $browserver = $temp[1];
  • $temp = explode(" ", $browserver);
  • $browserver = $temp[2];
  • $browser = "火狐";
  • }
  • //谷歌浏览器
  • if (ereg("Mozilla", $Agent) && ereg("Chrome", $Agent)) {
  • $temp = explode("(", $Agent);
  • $temp = explode(" ", $temp[2]);
  • $browserver = $temp['3']; //如果以后google升级不变位置的话就是它了
  • $browser = "谷歌";
  • }
  • //360safe浏览器
  • if (ereg("Mozilla", $Agent) && ereg("360SE", $Agent)) {
  • //因为360浏览器,没有版本……
  • $browserver = $browser = "360安全卫士";
  • }
  • if ($browser != "") {
  • //$browseinfo = $browser.$browserver;
  • $browseinfo = $browserver;
  • } else {
  • $browseinfo = "Unknown";
  • }
  • return $browseinfo;
  • }
  • /**
  • * 返回时间格式
  • * @name: prepareDate
  • * @desc: prepares a date in the proper format for specific database types
  • * given a UNIX timestamp
  • * @param: $timestamp: a UNIX timestamp
  • * @param: $fieldType: the type of field to format the date for
  • * (in MySQL, you have DATE, TIME, YEAR, and DATETIME)
  • */
  • function prepareDate($timestamp, $fieldType = 'DATETIME') {
  • $date = '';
  • if (!$timestamp === false && $timestamp > 0) {
  • switch ($fieldType) {
  • case 'DATE' :
  • $date = date('Y-m-d', $timestamp);
  • break;
  • case 'TIME' :
  • $date = date('H:i:s', $timestamp);
  • break;
  • case 'YEAR' :
  • $date = date('Y', $timestamp);
  • break;
  • default :
  • $date = date('Y-m-d H:i:s', $timestamp);
  • break;
  • }
  • }
  • return $date;
  • }
  • /**
  • * 适应多维数组的递归,并将其中重复的值去掉后返回
  • * @param array $array
  • * @return array
  • */
  • function super_unique($array) {
  • $result = array_map("unserialize", array_unique(array_map("serialize", $array)));
  • foreach ($result as $key => $value) {
  • if (is_array($value)) {
  • $result[$key] = super_unique($value);
  • }
  • }
  • return $result;
  • }
  • /**
  • * 如果数值不满足2位,自动补零
  • * @param int $num
  • * @return int
  • */
  • function fullzero($num){
  • if(strlen($num)!=2){
  • return '0'.$num;
  • }else{
  • return $num;
  • }
  • }
  • //返回上一个url
  • function get_visit_url(){
  • return $_SERVER['HTTP_REFERER'];
  • }
  • ?>
  • 复制代码 我常用的common function库


    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    1142

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    371

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    245

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    37

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    114

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    77

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    17

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    863

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    123

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    SciPy 教程
    SciPy 教程

    共10课时 | 1.7万人学习

    Kotlin 教程
    Kotlin 教程

    共23课时 | 3.8万人学习

    C 教程
    C 教程

    共75课时 | 4.9万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号