Home >Backend Development >PHP Tutorial >My commonly used common function library

My commonly used common function library

WBOY
WBOYOriginal
2016-07-25 09:09:14680browse
There are commonly used PHP function libraries such as zero padding, Chinese interception, halt, html jump, js jump, filtering html, checking the email is legal, converting hyperlinks in text into clickable connections, returning time format, etc.

  1. //Because it is used in both front and backend, it is placed in the supermario folder for easy reuse
  2. /**
  3. * Oh~ Cute decimal point~ Oh~ Cute thousand digit~
  4. * If there are more than 4 digits, add the third digit before it,
  5. * @param int $gold
  6. * @return string
  7. */
  8. function showGold($gold) {
  9. return number_format( $gold);
  10. }
  11. /**
  12. * Page compression output
  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. * Jump to the page without prompt
  27. * @param string $url
  28. * @param string $target
  29. */
  30. function go($url='', $target='parent') {
  31. if ($url != "") {
  32. echo('');
  33. } else {
  34. echo('' );
  35. }
  36. }
  37. /**
  38. * Clear cache, ECHO, then DIE (hateful javascript+php... plain text output, there will always be some null characters...)
  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 < 6; $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('');
  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. 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 < 1 ? 0 : $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) <= $length) {
  • return $string;
  • }
  • $string = htmlspecialchars($string);
  • $string = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $string);
  • $strcut = '';
  • $n = $tn = $noc = 0;
  • while ($n < strlen($string)) {
  • $t = ord($string[$n]);
  • if ($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
  • $tn = 1;
  • $n++;
  • $noc++;
  • } elseif (194 <= $t && $t <= 223) {
  • $tn = 2;
  • $n += 2;
  • $noc += 2;
  • } elseif (224 <= $t && $t < 239) {
  • $tn = 3;
  • $n += 3;
  • $noc += 2;
  • } elseif (240 <= $t && $t <= 247) {
  • $tn = 4;
  • $n += 4;
  • $noc += 2;
  • } elseif (248 <= $t && $t <= 251) {
  • $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);
  • }
  • /**
  • * Check the validity of 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;
  • }
  • }
  • /**
  • * Secure email address
  • *
  • * @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 < 16; $i++) {
  • $x[] = substr(' }
  • $x[] = '"';
  • if ($attributes != '') {
  • if (is_array($attributes)) {
  • foreach ($attributes as $key => $val) {
  • $x[] = ' ' . $key . '="';
  • for ($i = 0; $i < strlen($val); $i++) {
  • $x[] = "|" . ord(substr($val, $i, 1));
  • }
  • $x[] = '"';
  • }
  • } else {
  • for ($i = 0; $i < strlen($attributes); $i++) {
  • $x[] = substr($attributes, $i, 1);
  • }
  • }
  • }
  • $x[] = '>';
  • $temp = array();
  • for ($i = 0; $i < strlen($title); $i++) {
  • $ordinal = ord($title[$i]);
  • if ($ordinal < 128) {
  • $x[] = "|" . $ordinal;
  • } else {
  • if (count($temp) == 0) {
  • $count = ($ordinal < 224) ? 2 : 3;
  • }
  • $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();
  • ?> $buffer = ob_get_contents();
  • ob_end_clean();
  • if ($tmp == '' || $tmp == NULL) {
  • return $buffer;
  • } else {
  • echo $buffer;
  • }
  • }
  • /**
  • +------------------------------------------------ ----------
  • * Convert hyperlinks in text into clickable links
  • +-------------------------- --------------------------------
  • * @access public
  • +---------- --------------------------------------------------
  • * @ param string $text The string to be processed
  • +--------------------------------------------- ------------------
  • * @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);
  • }
  • /**
  • * Get the client browser
  • * @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 <= 7; $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;
  • }
  • /**
  • * Adapt to the recursion of multi-dimensional arrays and return after removing duplicate values ​​
  • * @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;
  • }
  • /**
  • * If the value does not meet 2 digits, zeros will be added automatically
  • * @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'];
  • }
  • ?>
  • 复制代码 My commonly used common function library


    Statement:
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
    Previous article:Copy Move Files - PHPNext article:Copy Move Files - PHP