CommonServer.class.php 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?php
  2. namespace Common\Server;
  3. use Common\Server\BaseServer;
  4. use Common\Model\SyspeiziModel;
  5. use Common\Cache\RedisCache;
  6. use Common\Model\BusinesseCollectionModel;
  7. /** @author hch
  8. * 公用server
  9. */
  10. class CommonServer extends BaseServer {
  11. private $cache;
  12. function __construct() {
  13. parent::__construct();
  14. $this->cache = new RedisCache();
  15. }
  16. public function get_rand_no() {
  17. return date("ymd", time()) . substr(microtime(), 2, 5) . sprintf('%02d', rand(0, 99));
  18. }
  19. function getIp() {
  20. $realip = '';
  21. $unknown = 'unknown';
  22. if (isset($_SERVER)) {
  23. if (isset($_SERVER['HTTP_X_FORWARDED_FOR']) && !empty($_SERVER['HTTP_X_FORWARDED_FOR']) && strcasecmp($_SERVER['HTTP_X_FORWARDED_FOR'], $unknown)) {
  24. $arr = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
  25. foreach ($arr as $ip) {
  26. $ip = trim($ip);
  27. if ($ip != 'unknown') {
  28. $realip = $ip;
  29. break;
  30. }
  31. }
  32. } else if (isset($_SERVER['HTTP_CLIENT_IP']) && !empty($_SERVER['HTTP_CLIENT_IP']) && strcasecmp($_SERVER['HTTP_CLIENT_IP'], $unknown)) {
  33. $realip = $_SERVER['HTTP_CLIENT_IP'];
  34. } else if (isset($_SERVER['REMOTE_ADDR']) && !empty($_SERVER['REMOTE_ADDR']) && strcasecmp($_SERVER['REMOTE_ADDR'], $unknown)) {
  35. $realip = $_SERVER['REMOTE_ADDR'];
  36. } else {
  37. $realip = $unknown;
  38. }
  39. } else {
  40. if (getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), $unknown)) {
  41. $realip = getenv("HTTP_X_FORWARDED_FOR");
  42. } else if (getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), $unknown)) {
  43. $realip = getenv("HTTP_CLIENT_IP");
  44. } else if (getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), $unknown)) {
  45. $realip = getenv("REMOTE_ADDR");
  46. } else {
  47. $realip = $unknown;
  48. }
  49. }
  50. $realip = preg_match("/[\d\.]{7,15}/", $realip, $matches) ? $matches[0] : $unknown;
  51. return $realip;
  52. }
  53. //根据ip获取所处城市
  54. public function getIpLookup($ip = '') {
  55. if (empty($ip)) {
  56. $ip = $this->getIp();
  57. }
  58. $res = @file_get_contents('http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js&ip=' . $ip);
  59. if (empty($res)) {
  60. return false;
  61. }
  62. $jsonMatches = array();
  63. preg_match('#\{.+?\}#', $res, $jsonMatches);
  64. if (!isset($jsonMatches[0])) {
  65. return false;
  66. }
  67. $json = json_decode($jsonMatches[0], true);
  68. if (isset($json['ret']) && $json['ret'] == 1) {
  69. $json['ip'] = $ip;
  70. unset($json['ret']);
  71. } else {
  72. return false;
  73. }
  74. return $json;
  75. }
  76. public function hidtel($phone) {
  77. $IsWhat = preg_match('/(0[0-9]{2,3}[-]?[2-9][0-9]{6,7}[-]?[0-9]?)/i', $phone); //固定电话
  78. if ($IsWhat == 1) {
  79. return preg_replace('/(0[0-9]{2,3}[-]?[2-9])[0-9]{3,4}([0-9]{3}[-]?[0-9]?)/i', '$1****$2', $phone);
  80. } else {
  81. return preg_replace('/(1[358]{1}[0-9])[0-9]{4}([0-9]{4})/i', '$1****$2', $phone);
  82. }
  83. }
  84. public function cut_str($string, $sublen, $start = 0, $code = 'UTF-8') {
  85. if ($code == 'UTF-8') {
  86. $pa = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/";
  87. preg_match_all($pa, $string, $t_string);
  88. if (count($t_string[0]) - $start > $sublen)
  89. return join('', array_slice($t_string[0], $start, $sublen));
  90. return join('', array_slice($t_string[0], $start, $sublen));
  91. }
  92. else {
  93. $start = $start * 2;
  94. $sublen = $sublen * 2;
  95. $strlen = strlen($string);
  96. $tmpstr = '';
  97. for ($i = 0; $i < $strlen; $i++) {
  98. if ($i >= $start && $i < ($start + $sublen)) {
  99. if (ord(substr($string, $i, 1)) > 129) {
  100. $tmpstr.= substr($string, $i, 2);
  101. } else {
  102. $tmpstr.= substr($string, $i, 1);
  103. }
  104. }
  105. if (ord(substr($string, $i, 1)) > 129)
  106. $i++;
  107. }
  108. //if(strlen($tmpstr)< $strlen ) $tmpstr.= "...";
  109. return $tmpstr;
  110. }
  111. }
  112. public function is_weixin() {
  113. if (strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false) {
  114. return true;
  115. } else {
  116. return false;
  117. }
  118. }
  119. public function cny($ns) {//阿位伯字母转换成大写中文
  120. static $cnums = array("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"),
  121. $cnyunits = array("圆", "角", "分"),
  122. $grees = array("拾", "佰", "仟", "万", "拾", "佰", "仟", "亿");
  123. list($ns1, $ns2) = explode(".", $ns, 2);
  124. $ns2 = array_filter(array($ns2[1], $ns2[0]));
  125. $ret = array_merge($ns2, array(implode("", _cny_map_unit(str_split($ns1), $grees)), ""));
  126. $ret = implode("", array_reverse(_cny_map_unit($ret, $cnyunits)));
  127. return str_replace(array_keys($cnums), $cnums, $ret);
  128. }
  129. }