common.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkPHP [ WE CAN DO IT JUST THINK ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
  8. // +----------------------------------------------------------------------
  9. // | Author: 流年 <liu21st@gmail.com>
  10. // +----------------------------------------------------------------------
  11. // 应用公共文件
  12. /**
  13. * 敏感词过滤
  14. *
  15. * @param string
  16. * @return string
  17. */
  18. function sensitive_words_filter($str)
  19. {
  20. if (!$str) return '';
  21. $file = ROOT_PATH. PUBILC_PATH.'/static/plug/censorwords/CensorWords';
  22. $words = file($file);
  23. foreach($words as $word)
  24. {
  25. $word = str_replace(array("\r\n","\r","\n","/","<",">","="," "), '', $word);
  26. if (!$word) continue;
  27. $ret = preg_match("/$word/", $str, $match);
  28. if ($ret) {
  29. return $match[0];
  30. }
  31. }
  32. return '';
  33. }
  34. /**
  35. * 上传路径转化,默认路径 UPLOAD_PATH
  36. * $type 类型
  37. */
  38. function makePathToUrl($path,$type = 2)
  39. {
  40. $path = DS.ltrim(rtrim($path));
  41. switch ($type){
  42. case 1:
  43. $path .= DS.date('Y');
  44. break;
  45. case 2:
  46. $path .= DS.date('Y').DS.date('m');
  47. break;
  48. case 3:
  49. $path .= DS.date('Y').DS.date('m').DS.date('d');
  50. break;
  51. }
  52. if (is_dir(ROOT_PATH.UPLOAD_PATH.$path) == true || mkdir(ROOT_PATH.UPLOAD_PATH.$path, 0777, true) == true) {
  53. return trim(str_replace(DS, '/',UPLOAD_PATH.$path),'.');
  54. }else return '';
  55. }
  56. // 过滤掉emoji表情
  57. function filterEmoji($str)
  58. {
  59. $str = preg_replace_callback( //执行一个正则表达式搜索并且使用一个回调进行替换
  60. '/./u',
  61. function (array $match) {
  62. return strlen($match[0]) >= 4 ? '' : $match[0];
  63. },
  64. $str);
  65. return $str;
  66. }
  67. //可逆加密
  68. function encrypt($data, $key) {
  69. $prep_code = serialize($data);
  70. $block = mcrypt_get_block_size('des', 'ecb');
  71. if (($pad = $block - (strlen($prep_code) % $block)) < $block) {
  72. $prep_code .= str_repeat(chr($pad), $pad);
  73. }
  74. $encrypt = mcrypt_encrypt(MCRYPT_DES, $key, $prep_code, MCRYPT_MODE_ECB);
  75. return base64_encode($encrypt);
  76. }
  77. //可逆解密
  78. function decrypt($str, $key) {
  79. $str = base64_decode($str);
  80. $str = mcrypt_decrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB);
  81. $block = mcrypt_get_block_size('des', 'ecb');
  82. $pad = ord($str[($len = strlen($str)) - 1]);
  83. if ($pad && $pad < $block && preg_match('/' . chr($pad) . '{' . $pad . '}$/', $str)) {
  84. $str = substr($str, 0, strlen($str) - $pad);
  85. }
  86. return unserialize($str);
  87. }
  88. //替换一部分字符
  89. /**
  90. * @param $string 需要替换的字符串
  91. * @param $start 开始的保留几位
  92. * @param $end 最后保留几位
  93. * @return string
  94. */
  95. function strReplace($string,$start,$end)
  96. {
  97. $strlen = mb_strlen($string, 'UTF-8');//获取字符串长度
  98. $firstStr = mb_substr($string, 0, $start,'UTF-8');//获取第一位
  99. $lastStr = mb_substr($string, -1, $end, 'UTF-8');//获取最后一位
  100. return $strlen == 2 ? $firstStr . str_repeat('*', mb_strlen($string, 'utf-8') -1) : $firstStr . str_repeat("*", $strlen - 2) . $lastStr;
  101. }