PageRenderTime 63ms CodeModel.GetById 22ms RepoModel.GetById 0ms app.codeStats 1ms

/phpcms/libs/functions/global.func.php

https://github.com/sinfey69/cms
PHP | 1701 lines | 1157 code | 98 blank | 446 comment | 321 complexity | 46f64dc2a266228146f836d7c77781a9 MD5 | raw file

Large files files are truncated, but you can click here to view the full file

  1. <?php
  2. /**
  3. * global.func.php 公共函数库
  4. *
  5. * @copyright (C) 2005-2010 PHPCMS
  6. * @license http://www.phpcms.cn/license/
  7. * @lastmodify 2010-6-1
  8. */
  9. /**
  10. * 返回经addslashes处理过的字符串或数组
  11. * @param $string 需要处理的字符串或数组
  12. * @return mixed
  13. */
  14. function new_addslashes($string){
  15. if(!is_array($string)) return addslashes($string);
  16. foreach($string as $key => $val) $string[$key] = new_addslashes($val);
  17. return $string;
  18. }
  19. /**
  20. * 返回经stripslashes处理过的字符串或数组
  21. * @param $string 需要处理的字符串或数组
  22. * @return mixed
  23. */
  24. function new_stripslashes($string) {
  25. if(!is_array($string)) return stripslashes($string);
  26. foreach($string as $key => $val) $string[$key] = new_stripslashes($val);
  27. return $string;
  28. }
  29. /**
  30. * 返回经htmlspecialchars处理过的字符串或数组
  31. * @param $obj 需要处理的字符串或数组
  32. * @return mixed
  33. */
  34. function new_html_special_chars($string) {
  35. $encoding = 'utf-8';
  36. if(strtolower(CHARSET)=='gbk') $encoding = 'ISO-8859-15';
  37. if(!is_array($string)) return htmlspecialchars($string,ENT_QUOTES,$encoding);
  38. foreach($string as $key => $val) $string[$key] = new_html_special_chars($val);
  39. return $string;
  40. }
  41. function new_html_entity_decode($string) {
  42. $encoding = 'utf-8';
  43. if(strtolower(CHARSET)=='gbk') $encoding = 'ISO-8859-15';
  44. return html_entity_decode($string,ENT_QUOTES,$encoding);
  45. }
  46. function new_htmlentities($string) {
  47. $encoding = 'utf-8';
  48. if(strtolower(CHARSET)=='gbk') $encoding = 'ISO-8859-15';
  49. return htmlentities($string,ENT_QUOTES,$encoding);
  50. }
  51. /**
  52. * 安全过滤函数
  53. *
  54. * @param $string
  55. * @return string
  56. */
  57. function safe_replace($string) {
  58. $string = str_replace('%20','',$string);
  59. $string = str_replace('%27','',$string);
  60. $string = str_replace('%2527','',$string);
  61. $string = str_replace('*','',$string);
  62. $string = str_replace('"','&quot;',$string);
  63. $string = str_replace("'",'',$string);
  64. $string = str_replace('"','',$string);
  65. $string = str_replace(';','',$string);
  66. $string = str_replace('<','&lt;',$string);
  67. $string = str_replace('>','&gt;',$string);
  68. $string = str_replace("{",'',$string);
  69. $string = str_replace('}','',$string);
  70. $string = str_replace('\\','',$string);
  71. return $string;
  72. }
  73. /**
  74. * xss过滤函数
  75. *
  76. * @param $string
  77. * @return string
  78. */
  79. function remove_xss($string) {
  80. $string = preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]+/S', '', $string);
  81. $parm1 = Array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
  82. $parm2 = Array('onabort', 'onactivate', 'onafterprint', 'onafterupdate', 'onbeforeactivate', 'onbeforecopy', 'onbeforecut', 'onbeforedeactivate', 'onbeforeeditfocus', 'onbeforepaste', 'onbeforeprint', 'onbeforeunload', 'onbeforeupdate', 'onblur', 'onbounce', 'oncellchange', 'onchange', 'onclick', 'oncontextmenu', 'oncontrolselect', 'oncopy', 'oncut', 'ondataavailable', 'ondatasetchanged', 'ondatasetcomplete', 'ondblclick', 'ondeactivate', 'ondrag', 'ondragend', 'ondragenter', 'ondragleave', 'ondragover', 'ondragstart', 'ondrop', 'onerror', 'onerrorupdate', 'onfilterchange', 'onfinish', 'onfocus', 'onfocusin', 'onfocusout', 'onhelp', 'onkeydown', 'onkeypress', 'onkeyup', 'onlayoutcomplete', 'onload', 'onlosecapture', 'onmousedown', 'onmouseenter', 'onmouseleave', 'onmousemove', 'onmouseout', 'onmouseover', 'onmouseup', 'onmousewheel', 'onmove', 'onmoveend', 'onmovestart', 'onpaste', 'onpropertychange', 'onreadystatechange', 'onreset', 'onresize', 'onresizeend', 'onresizestart', 'onrowenter', 'onrowexit', 'onrowsdelete', 'onrowsinserted', 'onscroll', 'onselect', 'onselectionchange', 'onselectstart', 'onstart', 'onstop', 'onsubmit', 'onunload');
  83. $parm = array_merge($parm1, $parm2);
  84. for ($i = 0; $i < sizeof($parm); $i++) {
  85. $pattern = '/';
  86. for ($j = 0; $j < strlen($parm[$i]); $j++) {
  87. if ($j > 0) {
  88. $pattern .= '(';
  89. $pattern .= '(&#[x|X]0([9][a][b]);?)?';
  90. $pattern .= '|(&#0([9][10][13]);?)?';
  91. $pattern .= ')?';
  92. }
  93. $pattern .= $parm[$i][$j];
  94. }
  95. $pattern .= '/i';
  96. $string = preg_replace($pattern, ' ', $string);
  97. }
  98. return $string;
  99. }
  100. /**
  101. * 过滤ASCII码从0-28的控制字符
  102. * @return String
  103. */
  104. function trim_unsafe_control_chars($str) {
  105. $rule = '/[' . chr ( 1 ) . '-' . chr ( 8 ) . chr ( 11 ) . '-' . chr ( 12 ) . chr ( 14 ) . '-' . chr ( 31 ) . ']*/';
  106. return str_replace ( chr ( 0 ), '', preg_replace ( $rule, '', $str ) );
  107. }
  108. /**
  109. * 格式化文本域内容
  110. *
  111. * @param $string 文本域内容
  112. * @return string
  113. */
  114. function trim_textarea($string) {
  115. $string = nl2br ( str_replace ( ' ', '&nbsp;', $string ) );
  116. return $string;
  117. }
  118. /**
  119. * 将文本格式成适合js输出的字符串
  120. * @param string $string 需要处理的字符串
  121. * @param intval $isjs 是否执行字符串格式化,默认为执行
  122. * @return string 处理后的字符串
  123. */
  124. function format_js($string, $isjs = 1) {
  125. $string = addslashes(str_replace(array("\r", "\n", "\t"), array('', '', ''), $string));
  126. return $isjs ? 'document.write("'.$string.'");' : $string;
  127. }
  128. /**
  129. * 转义 javascript 代码标记
  130. *
  131. * @param $str
  132. * @return mixed
  133. */
  134. function trim_script($str) {
  135. if(is_array($str)){
  136. foreach ($str as $key => $val){
  137. $str[$key] = trim_script($val);
  138. }
  139. }else{
  140. $str = preg_replace ( '/\<([\/]?)script([^\>]*?)\>/si', '&lt;\\1script\\2&gt;', $str );
  141. $str = preg_replace ( '/\<([\/]?)iframe([^\>]*?)\>/si', '&lt;\\1iframe\\2&gt;', $str );
  142. $str = preg_replace ( '/\<([\/]?)frame([^\>]*?)\>/si', '&lt;\\1frame\\2&gt;', $str );
  143. $str = str_replace ( 'javascript:', 'javascript:', $str );
  144. }
  145. return $str;
  146. }
  147. /**
  148. * 获取当前页面完整URL地址
  149. */
  150. function get_url() {
  151. $sys_protocal = isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://';
  152. $php_self = $_SERVER['PHP_SELF'] ? safe_replace($_SERVER['PHP_SELF']) : safe_replace($_SERVER['SCRIPT_NAME']);
  153. $path_info = isset($_SERVER['PATH_INFO']) ? safe_replace($_SERVER['PATH_INFO']) : '';
  154. $relate_url = isset($_SERVER['REQUEST_URI']) ? safe_replace($_SERVER['REQUEST_URI']) : $php_self.(isset($_SERVER['QUERY_STRING']) ? '?'.safe_replace($_SERVER['QUERY_STRING']) : $path_info);
  155. return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$relate_url;
  156. }
  157. /**
  158. * 字符截取 支持UTF8/GBK
  159. * @param $string
  160. * @param $length
  161. * @param $dot
  162. */
  163. function str_cut($string, $length, $dot = '...') {
  164. $strlen = strlen($string);
  165. if($strlen <= $length) return $string;
  166. $string = str_replace(array(' ','&nbsp;', '&amp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;'), array('∵',' ', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), $string);
  167. $strcut = '';
  168. if(strtolower(CHARSET) == 'utf-8') {
  169. $length = intval($length-strlen($dot)-$length/3);
  170. $n = $tn = $noc = 0;
  171. while($n < strlen($string)) {
  172. $t = ord($string[$n]);
  173. if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
  174. $tn = 1; $n++; $noc++;
  175. } elseif(194 <= $t && $t <= 223) {
  176. $tn = 2; $n += 2; $noc += 2;
  177. } elseif(224 <= $t && $t <= 239) {
  178. $tn = 3; $n += 3; $noc += 2;
  179. } elseif(240 <= $t && $t <= 247) {
  180. $tn = 4; $n += 4; $noc += 2;
  181. } elseif(248 <= $t && $t <= 251) {
  182. $tn = 5; $n += 5; $noc += 2;
  183. } elseif($t == 252 || $t == 253) {
  184. $tn = 6; $n += 6; $noc += 2;
  185. } else {
  186. $n++;
  187. }
  188. if($noc >= $length) {
  189. break;
  190. }
  191. }
  192. if($noc > $length) {
  193. $n -= $tn;
  194. }
  195. $strcut = substr($string, 0, $n);
  196. $strcut = str_replace(array('∵', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), array(' ', '&amp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;'), $strcut);
  197. } else {
  198. $dotlen = strlen($dot);
  199. $maxi = $length - $dotlen - 1;
  200. $current_str = '';
  201. $search_arr = array('&',' ', '"', "'", '“', '”', '—', '<', '>', '·', '…','∵');
  202. $replace_arr = array('&amp;','&nbsp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;',' ');
  203. $search_flip = array_flip($search_arr);
  204. for ($i = 0; $i < $maxi; $i++) {
  205. $current_str = ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
  206. if (in_array($current_str, $search_arr)) {
  207. $key = $search_flip[$current_str];
  208. $current_str = str_replace($search_arr[$key], $replace_arr[$key], $current_str);
  209. }
  210. $strcut .= $current_str;
  211. }
  212. }
  213. return $strcut.$dot;
  214. }
  215. /**
  216. * 获取请求ip
  217. *
  218. * @return ip地址
  219. */
  220. function ip() {
  221. if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) {
  222. $ip = getenv('HTTP_CLIENT_IP');
  223. } elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) {
  224. $ip = getenv('HTTP_X_FORWARDED_FOR');
  225. } elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) {
  226. $ip = getenv('REMOTE_ADDR');
  227. } elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) {
  228. $ip = $_SERVER['REMOTE_ADDR'];
  229. }
  230. return preg_match ( '/[\d\.]{7,15}/', $ip, $matches ) ? $matches [0] : '';
  231. }
  232. function get_cost_time() {
  233. $microtime = microtime ( TRUE );
  234. return $microtime - SYS_START_TIME;
  235. }
  236. /**
  237. * 程序执行时间
  238. *
  239. * @return int 单位ms
  240. */
  241. function execute_time() {
  242. $stime = explode ( ' ', SYS_START_TIME );
  243. $etime = explode ( ' ', microtime () );
  244. return number_format ( ($etime [1] + $etime [0] - $stime [1] - $stime [0]), 6 );
  245. }
  246. /**
  247. * 产生随机字符串
  248. *
  249. * @param int $length 输出长度
  250. * @param string $chars 可选的 ,默认为 0123456789
  251. * @return string 字符串
  252. */
  253. function random($length, $chars = '0123456789') {
  254. $hash = '';
  255. $max = strlen($chars) - 1;
  256. for($i = 0; $i < $length; $i++) {
  257. $hash .= $chars[mt_rand(0, $max)];
  258. }
  259. return $hash;
  260. }
  261. /**
  262. * 将字符串转换为数组
  263. *
  264. * @param string $data 字符串
  265. * @return array 返回数组格式,如果,data为空,则返回空数组
  266. */
  267. function string2array($data) {
  268. if($data == '') return array();
  269. @eval("\$array = $data;");
  270. return $array;
  271. }
  272. /**
  273. * 将数组转换为字符串
  274. *
  275. * @param array $data 数组
  276. * @param bool $isformdata 如果为0,则不使用new_stripslashes处理,可选参数,默认为1
  277. * @return string 返回字符串,如果,data为空,则返回空
  278. */
  279. function array2string($data, $isformdata = 1) {
  280. if($data == '') return '';
  281. if($isformdata) $data = new_stripslashes($data);
  282. return addslashes(var_export($data, TRUE));
  283. }
  284. /**
  285. * 转换字节数为其他单位
  286. *
  287. *
  288. * @param string $filesize 字节大小
  289. * @return string 返回大小
  290. */
  291. function sizecount($filesize) {
  292. if ($filesize >= 1073741824) {
  293. $filesize = round($filesize / 1073741824 * 100) / 100 .' GB';
  294. } elseif ($filesize >= 1048576) {
  295. $filesize = round($filesize / 1048576 * 100) / 100 .' MB';
  296. } elseif($filesize >= 1024) {
  297. $filesize = round($filesize / 1024 * 100) / 100 . ' KB';
  298. } else {
  299. $filesize = $filesize.' Bytes';
  300. }
  301. return $filesize;
  302. }
  303. /**
  304. * 字符串加密、解密函数
  305. *
  306. *
  307. * @param string $txt 字符串
  308. * @param string $operation ENCODE为加密,DECODE为解密,可选参数,默认为ENCODE,
  309. * @param string $key 密钥:数字、字母、下划线
  310. * @param string $expiry 过期时间
  311. * @return string
  312. */
  313. function sys_auth($string, $operation = 'ENCODE', $key = '', $expiry = 0) {
  314. $key_length = 4;
  315. $key = md5($key != '' ? $key : pc_base::load_config('system', 'auth_key'));
  316. $fixedkey = md5($key);
  317. $egiskeys = md5(substr($fixedkey, 16, 16));
  318. $runtokey = $key_length ? ($operation == 'ENCODE' ? substr(md5(microtime(true)), -$key_length) : substr($string, 0, $key_length)) : '';
  319. $keys = md5(substr($runtokey, 0, 16) . substr($fixedkey, 0, 16) . substr($runtokey, 16) . substr($fixedkey, 16));
  320. $string = $operation == 'ENCODE' ? sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$egiskeys), 0, 16) . $string : base64_decode(substr($string, $key_length));
  321. $i = 0; $result = '';
  322. $string_length = strlen($string);
  323. for ($i = 0; $i < $string_length; $i++){
  324. $result .= chr(ord($string{$i}) ^ ord($keys{$i % 32}));
  325. }
  326. if($operation == 'ENCODE') {
  327. return $runtokey . str_replace('=', '', base64_encode($result));
  328. } else {
  329. if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$egiskeys), 0, 16)) {
  330. return substr($result, 26);
  331. } else {
  332. return '';
  333. }
  334. }
  335. }
  336. /**
  337. * 语言文件处理
  338. *
  339. * @param string $language 标示符
  340. * @param array $pars 转义的数组,二维数组 ,'key1'=>'value1','key2'=>'value2',
  341. * @param string $modules 多个模块之间用半角逗号隔开,如:member,guestbook
  342. * @return string 语言字符
  343. */
  344. function L($language = 'no_language',$pars = array(), $modules = '') {
  345. static $LANG = array();
  346. static $LANG_MODULES = array();
  347. static $lang = '';
  348. if(defined('IN_ADMIN')) {
  349. $lang = SYS_STYLE ? SYS_STYLE : 'zh-cn';
  350. } else {
  351. $lang = pc_base::load_config('system','lang');
  352. }
  353. if(!$LANG) {
  354. require_once PC_PATH.'languages'.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.'system.lang.php';
  355. if(defined('IN_ADMIN')) require_once PC_PATH.'languages'.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.'system_menu.lang.php';
  356. if(file_exists(PC_PATH.'languages'.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.ROUTE_M.'.lang.php')) require_once PC_PATH.'languages'.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.ROUTE_M.'.lang.php';
  357. }
  358. if(!empty($modules)) {
  359. $modules = explode(',',$modules);
  360. foreach($modules AS $m) {
  361. if(!isset($LANG_MODULES[$m])) require_once PC_PATH.'languages'.DIRECTORY_SEPARATOR.$lang.DIRECTORY_SEPARATOR.$m.'.lang.php';
  362. }
  363. }
  364. if(!array_key_exists($language,$LANG)) {
  365. return $language;
  366. } else {
  367. $language = $LANG[$language];
  368. if($pars) {
  369. foreach($pars AS $_k=>$_v) {
  370. $language = str_replace('{'.$_k.'}',$_v,$language);
  371. }
  372. }
  373. return $language;
  374. }
  375. }
  376. /**
  377. * 模板调用
  378. *
  379. * @param $module
  380. * @param $template
  381. * @param $istag
  382. * @return unknown_type
  383. */
  384. function template($module = 'content', $template = 'index', $style = '') {
  385. if(strpos($module, 'plugin/')!== false) {
  386. $plugin = str_replace('plugin/', '', $module);
  387. return p_template($plugin, $template,$style);
  388. }
  389. $module = str_replace('/', DIRECTORY_SEPARATOR, $module);
  390. if(!empty($style) && preg_match('/([a-z0-9\-_]+)/is',$style)) {
  391. } elseif (empty($style) && !defined('STYLE')) {
  392. if(defined('SITEID')) {
  393. $siteid = SITEID;
  394. } else {
  395. $siteid = param::get_cookie('siteid');
  396. }
  397. if (!$siteid) $siteid = 1;
  398. $sitelist = getcache('sitelist','commons');
  399. if(!empty($siteid)) {
  400. $style = $sitelist[$siteid]['default_style'];
  401. }
  402. } elseif (empty($style) && defined('STYLE')) {
  403. $style = STYLE;
  404. } else {
  405. $style = 'default';
  406. }
  407. if(!$style) $style = 'default';
  408. $template_cache = pc_base::load_sys_class('template_cache');
  409. $compiledtplfile = PHPCMS_PATH.'caches'.DIRECTORY_SEPARATOR.'caches_template'.DIRECTORY_SEPARATOR.$style.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.php';
  410. if(file_exists(PC_PATH.'templates'.DIRECTORY_SEPARATOR.$style.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html')) {
  411. if(!file_exists($compiledtplfile) || (@filemtime(PC_PATH.'templates'.DIRECTORY_SEPARATOR.$style.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html') > @filemtime($compiledtplfile))) {
  412. $template_cache->template_compile($module, $template, $style);
  413. }
  414. } else {
  415. $compiledtplfile = PHPCMS_PATH.'caches'.DIRECTORY_SEPARATOR.'caches_template'.DIRECTORY_SEPARATOR.'default'.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.php';
  416. if(!file_exists($compiledtplfile) || (file_exists(PC_PATH.'templates'.DIRECTORY_SEPARATOR.'default'.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html') && filemtime(PC_PATH.'templates'.DIRECTORY_SEPARATOR.'default'.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html') > filemtime($compiledtplfile))) {
  417. $template_cache->template_compile($module, $template, 'default');
  418. } elseif (!file_exists(PC_PATH.'templates'.DIRECTORY_SEPARATOR.'default'.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html')) {
  419. showmessage('Template does not exist.'.DIRECTORY_SEPARATOR.$style.DIRECTORY_SEPARATOR.$module.DIRECTORY_SEPARATOR.$template.'.html');
  420. }
  421. }
  422. return $compiledtplfile;
  423. }
  424. /**
  425. * 输出自定义错误
  426. *
  427. * @param $errno 错误号
  428. * @param $errstr 错误描述
  429. * @param $errfile 报错文件地址
  430. * @param $errline 错误行号
  431. * @return string 错误提示
  432. */
  433. function my_error_handler($errno, $errstr, $errfile, $errline) {
  434. if($errno==8) return '';
  435. $errfile = str_replace(PHPCMS_PATH,'',$errfile);
  436. if(pc_base::load_config('system','errorlog')) {
  437. error_log('<?php exit;?>'.date('m-d H:i:s',SYS_TIME).' | '.$errno.' | '.str_pad($errstr,30).' | '.$errfile.' | '.$errline."\r\n", 3, CACHE_PATH.'error_log.php');
  438. } else {
  439. $str = '<div style="font-size:12px;text-align:left; border-bottom:1px solid #9cc9e0; border-right:1px solid #9cc9e0;padding:1px 4px;color:#000000;font-family:Arial, Helvetica,sans-serif;"><span>errorno:' . $errno . ',str:' . $errstr . ',file:<font color="blue">' . $errfile . '</font>,line' . $errline .'<br /><a href="http://faq.phpcms.cn/?type=file&errno='.$errno.'&errstr='.urlencode($errstr).'&errfile='.urlencode($errfile).'&errline='.$errline.'" target="_blank" style="color:red">Need Help?</a></span></div>';
  440. echo $str;
  441. }
  442. }
  443. /**
  444. * 提示信息页面跳转,跳转地址如果传入数组,页面会提示多个地址供用户选择,默认跳转地址为数组的第一个值,时间为5秒。
  445. * showmessage('登录成功', array('默认跳转地址'=>'http://www.phpcms.cn'));
  446. * @param string $msg 提示信息
  447. * @param mixed(string/array) $url_forward 跳转地址
  448. * @param int $ms 跳转等待时间
  449. */
  450. function showmessage($msg, $url_forward = 'goback', $ms = 1250, $dialog = '', $returnjs = '') {
  451. if(defined('IN_ADMIN')) {
  452. include(admin::admin_tpl('showmessage', 'admin'));
  453. } else {
  454. include(template('content', 'message'));
  455. }
  456. exit;
  457. }
  458. /**
  459. * 查询字符是否存在于某字符串
  460. *
  461. * @param $haystack 字符串
  462. * @param $needle 要查找的字符
  463. * @return bool
  464. */
  465. function str_exists($haystack, $needle)
  466. {
  467. return !(strpos($haystack, $needle) === FALSE);
  468. }
  469. /**
  470. * 取得文件扩展
  471. *
  472. * @param $filename 文件名
  473. * @return 扩展名
  474. */
  475. function fileext($filename) {
  476. return strtolower(trim(substr(strrchr($filename, '.'), 1, 10)));
  477. }
  478. /**
  479. * 加载模板标签缓存
  480. * @param string $name 缓存名
  481. * @param integer $times 缓存时间
  482. */
  483. function tpl_cache($name,$times = 0) {
  484. $filepath = 'tpl_data';
  485. $info = getcacheinfo($name, $filepath);
  486. if (SYS_TIME - $info['filemtime'] >= $times) {
  487. return false;
  488. } else {
  489. return getcache($name,$filepath);
  490. }
  491. }
  492. /**
  493. * 写入缓存,默认为文件缓存,不加载缓存配置。
  494. * @param $name 缓存名称
  495. * @param $data 缓存数据
  496. * @param $filepath 数据路径(模块名称) caches/cache_$filepath/
  497. * @param $type 缓存类型[file,memcache,apc]
  498. * @param $config 配置名称
  499. * @param $timeout 过期时间
  500. */
  501. function setcache($name, $data, $filepath='', $type='file', $config='', $timeout=0) {
  502. pc_base::load_sys_class('cache_factory','',0);
  503. if($config) {
  504. $cacheconfig = pc_base::load_config('cache');
  505. $cache = cache_factory::get_instance($cacheconfig)->get_cache($config);
  506. } else {
  507. $cache = cache_factory::get_instance()->get_cache($type);
  508. }
  509. return $cache->set($name, $data, $timeout, '', $filepath);
  510. }
  511. /**
  512. * 读取缓存,默认为文件缓存,不加载缓存配置。
  513. * @param string $name 缓存名称
  514. * @param $filepath 数据路径(模块名称) caches/cache_$filepath/
  515. * @param string $config 配置名称
  516. */
  517. function getcache($name, $filepath='', $type='file', $config='') {
  518. pc_base::load_sys_class('cache_factory','',0);
  519. if($config) {
  520. $cacheconfig = pc_base::load_config('cache');
  521. $cache = cache_factory::get_instance($cacheconfig)->get_cache($config);
  522. } else {
  523. $cache = cache_factory::get_instance()->get_cache($type);
  524. }
  525. return $cache->get($name, '', '', $filepath);
  526. }
  527. /**
  528. * 删除缓存,默认为文件缓存,不加载缓存配置。
  529. * @param $name 缓存名称
  530. * @param $filepath 数据路径(模块名称) caches/cache_$filepath/
  531. * @param $type 缓存类型[file,memcache,apc]
  532. * @param $config 配置名称
  533. */
  534. function delcache($name, $filepath='', $type='file', $config='') {
  535. pc_base::load_sys_class('cache_factory','',0);
  536. if($config) {
  537. $cacheconfig = pc_base::load_config('cache');
  538. $cache = cache_factory::get_instance($cacheconfig)->get_cache($config);
  539. } else {
  540. $cache = cache_factory::get_instance()->get_cache($type);
  541. }
  542. return $cache->delete($name, '', '', $filepath);
  543. }
  544. /**
  545. * 读取缓存,默认为文件缓存,不加载缓存配置。
  546. * @param string $name 缓存名称
  547. * @param $filepath 数据路径(模块名称) caches/cache_$filepath/
  548. * @param string $config 配置名称
  549. */
  550. function getcacheinfo($name, $filepath='', $type='file', $config='') {
  551. pc_base::load_sys_class('cache_factory');
  552. if($config) {
  553. $cacheconfig = pc_base::load_config('cache');
  554. $cache = cache_factory::get_instance($cacheconfig)->get_cache($config);
  555. } else {
  556. $cache = cache_factory::get_instance()->get_cache($type);
  557. }
  558. return $cache->cacheinfo($name, '', '', $filepath);
  559. }
  560. /**
  561. * 生成sql语句,如果传入$in_cloumn 生成格式为 IN('a', 'b', 'c')
  562. * @param $data 条件数组或者字符串
  563. * @param $front 连接符
  564. * @param $in_column 字段名称
  565. * @return string
  566. */
  567. function to_sqls($data, $front = ' AND ', $in_column = false) {
  568. if($in_column && is_array($data)) {
  569. $ids = '\''.implode('\',\'', $data).'\'';
  570. $sql = "$in_column IN ($ids)";
  571. return $sql;
  572. } else {
  573. if ($front == '') {
  574. $front = ' AND ';
  575. }
  576. if(is_array($data) && count($data) > 0) {
  577. $sql = '';
  578. foreach ($data as $key => $val) {
  579. $sql .= $sql ? " $front `$key` = '$val' " : " `$key` = '$val' ";
  580. }
  581. return $sql;
  582. } else {
  583. return $data;
  584. }
  585. }
  586. }
  587. /**
  588. * 分页函数
  589. *
  590. * @param $num 信息总数
  591. * @param $curr_page 当前分页
  592. * @param $perpage 每页显示数
  593. * @param $urlrule URL规则
  594. * @param $array 需要传递的数组,用于增加额外的方法
  595. * @return 分页
  596. */
  597. function pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {
  598. if(defined('URLRULE') && $urlrule == '') {
  599. $urlrule = URLRULE;
  600. $array = $GLOBALS['URL_ARRAY'];
  601. } elseif($urlrule == '') {
  602. $urlrule = url_par('page={$page}');
  603. }
  604. $multipage = '';
  605. if($num > $perpage) {
  606. $page = $setpages+1;
  607. $offset = ceil($setpages/2-1);
  608. $pages = ceil($num / $perpage);
  609. if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages);
  610. $from = $curr_page - $offset;
  611. $to = $curr_page + $offset;
  612. $more = 0;
  613. if($page >= $pages) {
  614. $from = 2;
  615. $to = $pages-1;
  616. } else {
  617. if($from <= 1) {
  618. $to = $page-1;
  619. $from = 2;
  620. } elseif($to >= $pages) {
  621. $from = $pages-($page-2);
  622. $to = $pages-1;
  623. }
  624. $more = 1;
  625. }
  626. $multipage .= '<a class="a1">'.$num.L('page_item').'</a>';
  627. if($curr_page>0) {
  628. $multipage .= ' <a href="'.pageurl($urlrule, $curr_page-1, $array).'" class="a1">'.L('previous').'</a>';
  629. if($curr_page==1) {
  630. $multipage .= ' <span>1</span>';
  631. } elseif($curr_page>6 && $more) {
  632. $multipage .= ' <a href="'.pageurl($urlrule, 1, $array).'">1</a>..';
  633. } else {
  634. $multipage .= ' <a href="'.pageurl($urlrule, 1, $array).'">1</a>';
  635. }
  636. }
  637. for($i = $from; $i <= $to; $i++) {
  638. if($i != $curr_page) {
  639. $multipage .= ' <a href="'.pageurl($urlrule, $i, $array).'">'.$i.'</a>';
  640. } else {
  641. $multipage .= ' <span>'.$i.'</span>';
  642. }
  643. }
  644. if($curr_page<$pages) {
  645. if($curr_page<$pages-5 && $more) {
  646. $multipage .= ' ..<a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'</a>';
  647. } else {
  648. $multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'</a>';
  649. }
  650. } elseif($curr_page==$pages) {
  651. $multipage .= ' <span>'.$pages.'</span> <a href="'.pageurl($urlrule, $curr_page, $array).'" class="a1">'.L('next').'</a>';
  652. } else {
  653. $multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'</a>';
  654. }
  655. }
  656. return $multipage;
  657. }
  658. /**
  659. * 返回分页路径
  660. *
  661. * @param $urlrule 分页规则
  662. * @param $page 当前页
  663. * @param $array 需要传递的数组,用于增加额外的方法
  664. * @return 完整的URL路径
  665. */
  666. function pageurl($urlrule, $page, $array = array()) {
  667. if(strpos($urlrule, '~')) {
  668. $urlrules = explode('~', $urlrule);
  669. $urlrule = $page < 2 ? $urlrules[0] : $urlrules[1];
  670. }
  671. $findme = array('{$page}');
  672. $replaceme = array($page);
  673. if (is_array($array)) foreach ($array as $k=>$v) {
  674. $findme[] = '{$'.$k.'}';
  675. $replaceme[] = $v;
  676. }
  677. $url = str_replace($findme, $replaceme, $urlrule);
  678. $url = str_replace(array('http://','//','~'), array('~','/','http://'), $url);
  679. return $url;
  680. }
  681. /**
  682. * URL路径解析,pages 函数的辅助函数
  683. *
  684. * @param $par 传入需要解析的变量 默认为,page={$page}
  685. * @param $url URL地址
  686. * @return URL
  687. */
  688. function url_par($par, $url = '') {
  689. if($url == '') $url = get_url();
  690. $pos = strpos($url, '?');
  691. if($pos === false) {
  692. $url .= '?'.$par;
  693. } else {
  694. $querystring = substr(strstr($url, '?'), 1);
  695. parse_str($querystring, $pars);
  696. $query_array = array();
  697. foreach($pars as $k=>$v) {
  698. if($k != 'page') $query_array[$k] = $v;
  699. }
  700. $querystring = http_build_query($query_array).'&'.$par;
  701. $url = substr($url, 0, $pos).'?'.$querystring;
  702. }
  703. return $url;
  704. }
  705. /**
  706. * 判断email格式是否正确
  707. * @param $email
  708. */
  709. function is_email($email) {
  710. return strlen($email) > 6 && preg_match("/^[\w\-\.]+@[\w\-\.]+(\.\w+)+$/", $email);
  711. }
  712. /**
  713. * iconv 编辑转换
  714. */
  715. if (!function_exists('iconv')) {
  716. function iconv($in_charset, $out_charset, $str) {
  717. $in_charset = strtoupper($in_charset);
  718. $out_charset = strtoupper($out_charset);
  719. if (function_exists('mb_convert_encoding')) {
  720. return mb_convert_encoding($str, $out_charset, $in_charset);
  721. } else {
  722. pc_base::load_sys_func('iconv');
  723. $in_charset = strtoupper($in_charset);
  724. $out_charset = strtoupper($out_charset);
  725. if ($in_charset == 'UTF-8' && ($out_charset == 'GBK' || $out_charset == 'GB2312')) {
  726. return utf8_to_gbk($str);
  727. }
  728. if (($in_charset == 'GBK' || $in_charset == 'GB2312') && $out_charset == 'UTF-8') {
  729. return gbk_to_utf8($str);
  730. }
  731. return $str;
  732. }
  733. }
  734. }
  735. /**
  736. * 代码广告展示函数
  737. * @param intval $siteid 所属站点
  738. * @param intval $id 广告ID
  739. * @return 返回广告代码
  740. */
  741. function show_ad($siteid, $id) {
  742. $siteid = intval($siteid);
  743. $id = intval($id);
  744. if(!$id || !$siteid) return false;
  745. $p = pc_base::load_model('poster_model');
  746. $r = $p->get_one(array('spaceid'=>$id, 'siteid'=>$siteid), 'disabled, setting', '`id` ASC');
  747. if ($r['disabled']) return '';
  748. if ($r['setting']) {
  749. $c = string2array($r['setting']);
  750. } else {
  751. $r['code'] = '';
  752. }
  753. return $c['code'];
  754. }
  755. /**
  756. * 获取当前的站点ID
  757. */
  758. function get_siteid() {
  759. static $siteid;
  760. if (!empty($siteid)) return $siteid;
  761. if (defined('IN_ADMIN')) {
  762. if ($d = param::get_cookie('siteid')) {
  763. $siteid = $d;
  764. } else {
  765. return '';
  766. }
  767. } else {
  768. $data = getcache('sitelist', 'commons');
  769. if(!is_array($data)) return '1';
  770. $site_url = SITE_PROTOCOL.SITE_URL;
  771. foreach ($data as $v) {
  772. if ($v['url'] == $site_url.'/') $siteid = $v['siteid'];
  773. }
  774. }
  775. if (empty($siteid)) $siteid = 1;
  776. return $siteid;
  777. }
  778. /**
  779. * 获取用户昵称
  780. * 不传入userid取当前用户nickname,如果nickname为空取username
  781. * 传入field,取用户$field字段信息
  782. */
  783. function get_nickname($userid='', $field='') {
  784. $return = '';
  785. if(is_numeric($userid)) {
  786. $member_db = pc_base::load_model('member_model');
  787. $memberinfo = $member_db->get_one(array('userid'=>$userid));
  788. if(!empty($field) && $field != 'nickname' && isset($memberinfo[$field]) &&!empty($memberinfo[$field])) {
  789. $return = $memberinfo[$field];
  790. } else {
  791. $return = isset($memberinfo['nickname']) && !empty($memberinfo['nickname']) ? $memberinfo['nickname'].'('.$memberinfo['username'].')' : $memberinfo['username'];
  792. }
  793. } else {
  794. if (param::get_cookie('_nickname')) {
  795. $return .= '('.param::get_cookie('_nickname').')';
  796. } else {
  797. $return .= '('.param::get_cookie('_username').')';
  798. }
  799. }
  800. return $return;
  801. }
  802. /**
  803. * 获取用户信息
  804. * 不传入$field返回用户所有信息,
  805. * 传入field,取用户$field字段信息
  806. */
  807. function get_memberinfo($userid, $field='') {
  808. if(!is_numeric($userid)) {
  809. return false;
  810. } else {
  811. static $memberinfo;
  812. if (!isset($memberinfo[$userid])) {
  813. $member_db = pc_base::load_model('member_model');
  814. $memberinfo[$userid] = $member_db->get_one(array('userid'=>$userid));
  815. }
  816. if(!empty($field) && !empty($memberinfo[$userid][$field])) {
  817. return $memberinfo[$userid][$field];
  818. } else {
  819. return $memberinfo[$userid];
  820. }
  821. }
  822. }
  823. /**
  824. * 通过 username 值,获取用户所有信息
  825. * 获取用户信息
  826. * 不传入$field返回用户所有信息,
  827. * 传入field,取用户$field字段信息
  828. */
  829. function get_memberinfo_buyusername($username, $field='') {
  830. if(empty($username)){return false;}
  831. static $memberinfo;
  832. if (!isset($memberinfo[$username])) {
  833. $member_db = pc_base::load_model('member_model');
  834. $memberinfo[$username] = $member_db->get_one(array('username'=>$username));
  835. }
  836. if(!empty($field) && !empty($memberinfo[$username][$field])) {
  837. return $memberinfo[$username][$field];
  838. } else {
  839. return $memberinfo[$username];
  840. }
  841. }
  842. /**
  843. * 获取用户头像,建议传入phpssouid
  844. * @param $uid 默认为phpssouid
  845. * @param $is_userid $uid是否为v9 userid,如果为真,执行sql查询此用户的phpssouid
  846. * @param $size 头像大小 有四种[30x30 45x45 90x90 180x180] 默认30
  847. */
  848. function get_memberavatar($uid, $is_userid='', $size='30') {
  849. if($is_userid) {
  850. $db = pc_base::load_model('member_model');
  851. $memberinfo = $db->get_one(array('userid'=>$uid));
  852. if(isset($memberinfo['phpssouid'])) {
  853. $uid = $memberinfo['phpssouid'];
  854. } else {
  855. return false;
  856. }
  857. }
  858. pc_base::load_app_class('client', 'member', 0);
  859. define('APPID', pc_base::load_config('system', 'phpsso_appid'));
  860. $phpsso_api_url = pc_base::load_config('system', 'phpsso_api_url');
  861. $phpsso_auth_key = pc_base::load_config('system', 'phpsso_auth_key');
  862. $client = new client($phpsso_api_url, $phpsso_auth_key);
  863. $avatar = $client->ps_getavatar($uid);
  864. if(isset($avatar[$size])) {
  865. return $avatar[$size];
  866. } else {
  867. return false;
  868. }
  869. }
  870. /**
  871. * 调用关联菜单
  872. * @param $linkageid 联动菜单id
  873. * @param $id 生成联动菜单的样式id
  874. * @param $defaultvalue 默认值
  875. */
  876. function menu_linkage($linkageid = 0, $id = 'linkid', $defaultvalue = 0) {
  877. $linkageid = intval($linkageid);
  878. $datas = array();
  879. $datas = getcache($linkageid,'linkage');
  880. $infos = $datas['data'];
  881. if($datas['style']=='1') {
  882. $title = $datas['title'];
  883. $container = 'content'.random(3).date('is');
  884. if(!defined('DIALOG_INIT_1')) {
  885. define('DIALOG_INIT_1', 1);
  886. $string .= '<script type="text/javascript" src="'.JS_PATH.'dialog.js"></script>';
  887. //TODO $string .= '<link href="'.CSS_PATH.'dialog.css" rel="stylesheet" type="text/css">';
  888. }
  889. if(!defined('LINKAGE_INIT_1')) {
  890. define('LINKAGE_INIT_1', 1);
  891. $string .= '<script type="text/javascript" src="'.JS_PATH.'linkage/js/pop.js"></script>';
  892. }
  893. $var_div = $defaultvalue && (ROUTE_A=='edit' || ROUTE_A=='account_manage_info' || ROUTE_A=='info_publish' || ROUTE_A=='orderinfo') ? menu_linkage_level($defaultvalue,$linkageid,$infos) : $datas['title'];
  894. $var_input = $defaultvalue && (ROUTE_A=='edit' || ROUTE_A=='account_manage_info' || ROUTE_A=='info_publish') ? '<input type="hidden" name="info['.$id.']" value="'.$defaultvalue.'">' : '<input type="hidden" name="info['.$id.']" value="">';
  895. $string .= '<div name="'.$id.'" value="" id="'.$id.'" class="ib">'.$var_div.'</div>'.$var_input.' <input type="button" name="btn_'.$id.'" class="button" value="'.L('linkage_select').'" onclick="open_linkage(\''.$id.'\',\''.$title.'\','.$container.',\''.$linkageid.'\')">';
  896. $string .= '<script type="text/javascript">';
  897. $string .= 'var returnid_'.$id.'= \''.$id.'\';';
  898. $string .= 'var returnkeyid_'.$id.' = \''.$linkageid.'\';';
  899. $string .= 'var '.$container.' = new Array(';
  900. foreach($infos AS $k=>$v) {
  901. if($v['parentid'] == 0) {
  902. $s[]='new Array(\''.$v['linkageid'].'\',\''.$v['name'].'\',\''.$v['parentid'].'\')';
  903. } else {
  904. continue;
  905. }
  906. }
  907. $s = implode(',',$s);
  908. $string .=$s;
  909. $string .= ')';
  910. $string .= '</script>';
  911. } elseif($datas['style']=='2') {
  912. if(!defined('LINKAGE_INIT_1')) {
  913. define('LINKAGE_INIT_1', 1);
  914. $string .= '<script type="text/javascript" src="'.JS_PATH.'linkage/js/jquery.ld.js"></script>';
  915. }
  916. $default_txt = '';
  917. if($defaultvalue) {
  918. $default_txt = menu_linkage_level($defaultvalue,$linkageid,$infos);
  919. $default_txt = '["'.str_replace(' > ','","',$default_txt).'"]';
  920. }
  921. $string .= $defaultvalue && (ROUTE_A=='edit' || ROUTE_A=='account_manage_info' || ROUTE_A=='info_publish') ? '<input type="hidden" name="info['.$id.']" id="'.$id.'" value="'.$defaultvalue.'">' : '<input type="hidden" name="info['.$id.']" id="'.$id.'" value="">';
  922. for($i=1;$i<=$datas['setting']['level'];$i++) {
  923. $string .='<select class="pc-select-'.$id.'" name="'.$id.'-'.$i.'" id="'.$id.'-'.$i.'" width="100"><option value="">请选择菜单</option></select> ';
  924. }
  925. $string .= '<script type="text/javascript">
  926. $(function(){
  927. var $ld5 = $(".pc-select-'.$id.'");
  928. $ld5.ld({ajaxOptions : {"url" : "'.APP_PATH.'api.php?op=get_linkage&act=ajax_select&keyid='.$linkageid.'"},defaultParentId : 0,style : {"width" : 120}})
  929. var ld5_api = $ld5.ld("api");
  930. ld5_api.selected('.$default_txt.');
  931. $ld5.bind("change",onchange);
  932. function onchange(e){
  933. var $target = $(e.target);
  934. var index = $ld5.index($target);
  935. $("#'.$id.'-'.$i.'").remove();
  936. $("#'.$id.'").val($ld5.eq(index).show().val());
  937. index ++;
  938. $ld5.eq(index).show(); }
  939. })
  940. </script>';
  941. } else {
  942. $title = $defaultvalue ? $infos[$defaultvalue]['name'] : $datas['title'];
  943. $colObj = random(3).date('is');
  944. $string = '';
  945. if(!defined('LINKAGE_INIT')) {
  946. define('LINKAGE_INIT', 1);
  947. $string .= '<script type="text/javascript" src="'.JS_PATH.'linkage/js/mln.colselect.js"></script>';
  948. if(defined('IN_ADMIN')) {
  949. $string .= '<link href="'.JS_PATH.'linkage/style/admin.css" rel="stylesheet" type="text/css">';
  950. } else {
  951. $string .= '<link href="'.JS_PATH.'linkage/style/css.css" rel="stylesheet" type="text/css">';
  952. }
  953. }
  954. $string .= '<input type="hidden" name="info['.$id.']" value="1"><div id="'.$id.'"></div>';
  955. $string .= '<script type="text/javascript">';
  956. $string .= 'var colObj'.$colObj.' = {"Items":[';
  957. foreach($infos AS $k=>$v) {
  958. $s .= '{"name":"'.$v['name'].'","topid":"'.$v['parentid'].'","colid":"'.$k.'","value":"'.$k.'","fun":function(){}},';
  959. }
  960. $string .= substr($s, 0, -1);
  961. $string .= ']};';
  962. $string .= '$("#'.$id.'").mlnColsel(colObj'.$colObj.',{';
  963. $string .= 'title:"'.$title.'",';
  964. $string .= 'value:"'.$defaultvalue.'",';
  965. $string .= 'width:100';
  966. $string .= '});';
  967. $string .= '</script>';
  968. }
  969. return $string;
  970. }
  971. /**
  972. * 联动菜单层级
  973. */
  974. function menu_linkage_level($linkageid,$keyid,$infos,$result=array()) {
  975. if(array_key_exists($linkageid,$infos)) {
  976. $result[]=$infos[$linkageid]['name'];
  977. return menu_linkage_level($infos[$linkageid]['parentid'],$keyid,$infos,$result);
  978. }
  979. krsort($result);
  980. return implode(' > ',$result);
  981. }
  982. /**
  983. * 通过catid获取显示菜单完整结构
  984. * @param $menuid 菜单ID
  985. * @param $cache_file 菜单缓存文件名称
  986. * @param $cache_path 缓存文件目录
  987. * @param $key 取得缓存值的键值名称
  988. * @param $parentkey 父级的ID
  989. * @param $linkstring 链接字符
  990. */
  991. function menu_level($menuid, $cache_file, $cache_path = 'commons', $key = 'catname', $parentkey = 'parentid', $linkstring = ' > ', $result=array()) {
  992. $menu_arr = getcache($cache_file, $cache_path);
  993. if (array_key_exists($menuid, $menu_arr)) {
  994. $result[] = $menu_arr[$menuid][$key];
  995. return menu_level($menu_arr[$menuid][$parentkey], $cache_file, $cache_path, $key, $parentkey, $linkstring, $result);
  996. }
  997. krsort($result);
  998. return implode($linkstring, $result);
  999. }
  1000. /**
  1001. * 通过id获取显示联动菜单
  1002. * @param $linkageid 联动菜单ID
  1003. * @param $keyid 菜单keyid
  1004. * @param $space 菜单间隔符
  1005. * @param $tyoe 1 返回间隔符链接,完整路径名称 3 返回完整路径数组,2返回当前联动菜单名称,4 直接返回ID
  1006. * @param $result 递归使用字段1
  1007. * @param $infos 递归使用字段2
  1008. */
  1009. function get_linkage($linkageid, $keyid, $space = '>', $type = 1, $result = array(), $infos = array()) {
  1010. if($space=='' || !isset($space))$space = '>';
  1011. if(!$infos) {
  1012. $datas = getcache($keyid,'linkage');
  1013. $infos = $datas['data'];
  1014. }
  1015. if($type == 1 || $type == 3 || $type == 4) {
  1016. if(array_key_exists($linkageid,$infos)) {
  1017. $result[]= ($type == 1) ? $infos[$linkageid]['name'] : (($type == 4) ? $linkageid :$infos[$linkageid]);
  1018. return get_linkage($infos[$linkageid]['parentid'], $keyid, $space, $type, $result, $infos);
  1019. } else {
  1020. if(count($result)>0) {
  1021. krsort($result);
  1022. if($type == 1 || $type == 4) $result = implode($space,$result);
  1023. return $result;
  1024. } else {
  1025. return $result;
  1026. }
  1027. }
  1028. } else {
  1029. return $infos[$linkageid]['name'];
  1030. }
  1031. }
  1032. /**
  1033. * IE浏览器判断
  1034. */
  1035. function is_ie() {
  1036. $useragent = strtolower($_SERVER['HTTP_USER_AGENT']);
  1037. if((strpos($useragent, 'opera') !== false) || (strpos($useragent, 'konqueror') !== false)) return false;
  1038. if(strpos($useragent, 'msie ') !== false) return true;
  1039. return false;
  1040. }
  1041. /**
  1042. * 文件下载
  1043. * @param $filepath 文件路径
  1044. * @param $filename 文件名称
  1045. */
  1046. function file_down($filepath, $filename = '') {
  1047. if(!$filename) $filename = basename($filepath);
  1048. if(is_ie()) $filename = rawurlencode($filename);
  1049. $filetype = fileext($filename);
  1050. $filesize = sprintf("%u", filesize($filepath));
  1051. if(ob_get_length() !== false) @ob_end_clean();
  1052. header('Pragma: public');
  1053. header('Last-Modified: '.gmdate('D, d M Y H:i:s') . ' GMT');
  1054. header('Cache-Control: no-store, no-cache, must-revalidate');
  1055. header('Cache-Control: pre-check=0, post-check=0, max-age=0');
  1056. header('Content-Transfer-Encoding: binary');
  1057. header('Content-Encoding: none');
  1058. header('Content-type: '.$filetype);
  1059. header('Content-Disposition: attachment; filename="'.$filename.'"');
  1060. header('Content-length: '.$filesize);
  1061. readfile($filepath);
  1062. exit;
  1063. }
  1064. /**
  1065. * 判断字符串是否为utf8编码,英文和半角字符返回ture
  1066. * @param $string
  1067. * @return bool
  1068. */
  1069. function is_utf8($string) {
  1070. return preg_match('%^(?:
  1071. [\x09\x0A\x0D\x20-\x7E] # ASCII
  1072. | [\xC2-\xDF][\x80-\xBF] # non-overlong 2-byte
  1073. | \xE0[\xA0-\xBF][\x80-\xBF] # excluding overlongs
  1074. | [\xE1-\xEC\xEE\xEF][\x80-\xBF]{2} # straight 3-byte
  1075. | \xED[\x80-\x9F][\x80-\xBF] # excluding surrogates
  1076. | \xF0[\x90-\xBF][\x80-\xBF]{2} # planes 1-3
  1077. | [\xF1-\xF3][\x80-\xBF]{3} # planes 4-15
  1078. | \xF4[\x80-\x8F][\x80-\xBF]{2} # plane 16
  1079. )*$%xs', $string);
  1080. }
  1081. /**
  1082. * 组装生成ID号
  1083. * @param $modules 模块名
  1084. * @param $contentid 内容ID
  1085. * @param $siteid 站点ID
  1086. */
  1087. function id_encode($modules,$contentid, $siteid) {
  1088. return urlencode($modules.'-'.$contentid.'-'.$siteid);
  1089. }
  1090. /**
  1091. * 解析ID
  1092. * @param $id 评论ID
  1093. */
  1094. function id_decode($id) {
  1095. return explode('-', $id);
  1096. }
  1097. /**
  1098. * 对用户的密码进行加密
  1099. * @param $password
  1100. * @param $encrypt //传入加密串,在修改密码时做认证
  1101. * @return array/password
  1102. */
  1103. function password($password, $encrypt='') {
  1104. $pwd = array();
  1105. $pwd['encrypt'] = $encrypt ? $encrypt : create_randomstr();
  1106. $pwd['password'] = md5(md5(trim($password)).$pwd['encrypt']);
  1107. return $encrypt ? $pwd['password'] : $pwd;
  1108. }
  1109. /**
  1110. * 生成随机字符串
  1111. * @param string $lenth 长度
  1112. * @return string 字符串
  1113. */
  1114. function create_randomstr($lenth = 6) {
  1115. return random($lenth, '123456789abcdefghijklmnpqrstuvwxyzABCDEFGHIJKLMNPQRSTUVWXYZ');
  1116. }
  1117. /**
  1118. * 检查密码长度是否符合规定
  1119. *
  1120. * @param STRING $password
  1121. * @return TRUE or FALSE
  1122. */
  1123. function is_password($password) {
  1124. $strlen = strlen($password);
  1125. if($strlen >= 6 && $strlen <= 20) return true;
  1126. return false;
  1127. }
  1128. /**
  1129. * 检测输入中是否含有错误字符
  1130. *
  1131. * @param char $string 要检查的字符串名称
  1132. * @return TRUE or FALSE
  1133. */
  1134. function is_badword($string) {
  1135. $badwords = array("\\",'&',' ',"'",'"','/','*',',','<','>',"\r","\t","\n","#");
  1136. foreach($badwords as $value){
  1137. if(strpos($string, $value) !== FALSE) {
  1138. return TRUE;
  1139. }
  1140. }
  1141. return FALSE;
  1142. }
  1143. /**
  1144. * 检查用户名是否符合规定
  1145. *
  1146. * @param STRING $username 要检查的用户名
  1147. * @return TRUE or FALSE
  1148. */
  1149. function is_username($username) {
  1150. $strlen = strlen($username);
  1151. if(is_badword($username) || !preg_match("/^[a-zA-Z0-9_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]+$/", $username)){
  1152. return false;
  1153. } elseif ( 20 < $strlen || $strlen < 2 ) {
  1154. return false;
  1155. }
  1156. return true;
  1157. }
  1158. /**
  1159. * 检查id是否存在于数组中
  1160. *
  1161. * @param $id
  1162. * @param $ids
  1163. * @param $s
  1164. */
  1165. function check_in($id, $ids = '', $s = ',') {
  1166. if(!$ids) return false;
  1167. $ids = explode($s, $ids);
  1168. return is_array($id) ? array_intersect($id, $ids) : in_array($id, $ids);
  1169. }
  1170. /**
  1171. * 对数据进行编码转换
  1172. * @param array/string $data 数组
  1173. * @param string $input 需要转换的编码
  1174. * @param string $output 转换后的编码
  1175. */
  1176. function array_iconv($data, $input = 'gbk', $output = 'utf-8') {
  1177. if (!is_array($data)) {
  1178. return iconv($input, $output, $data);
  1179. } else {
  1180. foreach ($data as $key=>$val) {
  1181. if(is_array($val)) {
  1182. $data[$key] = array_iconv($val, $input, $output);
  1183. } else {
  1184. $data[$key] = iconv($input, $output, $val);
  1185. }
  1186. }
  1187. return $data;
  1188. }
  1189. }
  1190. /**
  1191. * 生成缩略图函数
  1192. * @param $imgurl 图片路径
  1193. * @param $width 缩略图宽度
  1194. * @param $height 缩略图高度
  1195. * @param $autocut 是否自动裁剪 默认裁剪,当高度或宽度有一个数值为0是,自动关闭
  1196. * @param $smallpic 无图片是默认图片路径
  1197. */
  1198. function thumb($imgurl, $width = 100, $height = 100 ,$autocut = 1, $smallpic = 'nopic.gif') {
  1199. global $image;
  1200. $upload_url = pc_base::load_config('system','upload_url');
  1201. $upload_path = pc_base::load_config('system','upload_path');
  1202. if(empty($imgurl)) return IMG_PATH.$smallpic;
  1203. $imgurl_replace= str_replace($upload_url, '', $imgurl);
  1204. if(!extension_loaded('gd') || strpos($imgurl_replace, '://')) return $imgurl;
  1205. if(!file_exists($upload_path.$imgurl_replace)) return IMG_PATH.$smallpic;
  1206. list($width_t, $height_t, $type, $attr) = getimagesize($upload_path.$imgurl_replace);
  1207. if($width>=$width_t || $height>=$height_t) return $imgurl;
  1208. $newimgurl = dirname($imgurl_replace).'/thumb_'.$width.'_'.$height.'_'.basename($imgurl_replace);
  1209. if(file_exists($upload_path.$newimgurl)) return $upload_url.$newimgurl;
  1210. if(!is_object($image)) {
  1211. pc_base::load_sys_class('image','','0');
  1212. $image = new image(1,0);
  1213. }
  1214. return $image->thumb($upload_path.$imgurl_replace, $upload_path.$newimgurl, $width, $height, '', $autocut) ? $upload_url.$newimgurl : $imgurl;
  1215. }
  1216. /**
  1217. * 水印添加
  1218. * @param $source 原图片路径
  1219. * @param $target 生成水印图片途径,默认为空,覆盖原图
  1220. * @param $siteid 站点id,系统需根据站点id获取水印信息
  1221. */
  1222. function watermark($source, $target = '',$siteid) {
  1223. global $image_w;
  1224. if(empty($source)) return $source;
  1225. if(!extension_loaded('gd') || strpos($source, '://')) return $source;
  1226. if(!$target) $target = $source;
  1227. if(!is_object($image_w)){
  1228. pc_base::load_sys_class('image','','0');
  1229. $image_w = new image(0,$siteid);
  1230. }
  1231. $image_w->watermark($source, $target);
  1232. return $target;
  1233. }
  1234. /**
  1235. * 当前路径
  1236. * 返回指定栏目路径层级
  1237. * @param $catid 栏目id
  1238. * @param $symbol 栏目间隔符
  1239. */
  1240. function catpos($catid, $symbol=' > '){
  1241. $category_arr = array();
  1242. $siteids = getcache('category_content','commons');
  1243. $siteid = $siteids[$catid];
  1244. $category_arr = getcache('category_content_'.$siteid,'commons');
  1245. if(!isset($category_arr[$catid])) return '';
  1246. $pos = '';
  1247. $siteurl = siteurl($category_arr[$catid]['siteid']);
  1248. $arrparentid = array_filter(explode(',', $category_arr[$catid]['arrparentid'].','.$catid));
  1249. foreach($arrparentid as $catid) {
  1250. $url = $category_arr[$catid]['url'];
  1251. if(strpos($url, '://') === false) $url = $siteurl.$url;
  1252. $pos .= '<a href="'.$url.'">'.$category_arr[$catid]['catname'].'</a>'.$symbol;
  1253. }
  1254. return $pos;
  1255. }
  1256. /**
  1257. * 根据catid获取子栏目数据的sql语句
  1258. * @param string $module 缓存文件名
  1259. * @param intval $catid 栏目ID
  1260. */
  1261. function get_sql_catid($file = 'category_content_1', $catid = 0, $module = 'commons') {
  1262. $category = getcache($file,$module);
  1263. $catid = intval($catid);
  1264. if(!isset($category[$catid])) return false;
  1265. return $category[$catid]['child'] ? " `catid` IN(".$category[$catid]['arrchildid'].") " : " `catid`=$catid ";
  1266. }
  1267. /**
  1268. * 获取子栏目
  1269. * @param $parentid 父级id
  1270. * @param $type 栏目类型
  1271. * @param $self 是否包含本身 0为不包含
  1272. * @param $siteid 站点id
  1273. */
  1274. function subcat($parentid = NULL, $type = NULL,$self = '0', $siteid = '') {
  1275. if (empty($siteid)) $siteid = get_siteid();
  1276. $category = getcache('category_content_'.$siteid,'commons');
  1277. foreach($category as $id=>$cat) {
  1278. if($cat['siteid'] == $siteid && ($parentid === NULL || $cat['parentid'] == $parentid) && ($type === NULL || $cat['type'] == $type)) $subcat[$id] = $cat;
  1279. if($self == 1 && $cat['catid'] == $parentid && !$cat['child']) $subcat[$id] = $cat;
  1280. }
  1281. return $subcat;
  1282. }
  1283. /**
  1284. * 获取内容地址
  1285. * @param $catid 栏目ID
  1286. * @param $id 文章ID
  1287. * @param $allurl 是否以绝对路径返回
  1288. */
  1289. function go($catid,$id, $allurl = 0) {
  1290. static $category;
  1291. if(empty($category)) {
  1292. $siteids = getcache('category_content','commons');
  1293. $siteid = $siteids[$catid];
  1294. $category = getcache('category_content_'.$siteid,'commons');
  1295. }
  1296. $id = intval($id);
  1297. if(!$id || !isset($category[$catid])) return '';
  1298. $modelid = $category[$catid]['modelid'];
  1299. if(!$modelid) return '';
  1300. $db = pc_base::load_model('content_model');
  1301. $db->set_model($modelid);
  1302. $r = $db->get_one(array('id'=>$id), '`url`');
  1303. if (!empty($allurl)) {
  1304. if (strpos($r['url'], '://')===false) {
  1305. if (strpos($category[$catid]['url'], '://') === FALSE) {
  1306. $site = siteinfo($category[$catid]['siteid']);
  1307. $r['url'] = substr($site['domain'], 0, -1).$r['url'];
  1308. } else {
  1309. $r['url'] = $category[$catid]['url'].$r['url'];
  1310. }
  1311. }
  1312. }
  1313. return $r['url'];
  1314. }
  1315. /**
  1316. * 将附件地址转换为绝对地址
  1317. * @param $path 附件地址
  1318. */
  1319. function atturl($path) {
  1320. if(strpos($path, ':/')) {
  1321. return $path;
  1322. } else {
  1323. $sitelist = getcache('sitelist','commons');
  1324. $siteid = get_siteid();
  1325. $siteurl = $sitelist[$siteid]['domain'];
  1326. $domainlen = strlen($sitelist[$siteid]['domain'])-1;
  1327. $path = $siteurl.$path;
  1328. $path = substr_replace($path, '/', strpos($path, '//',$domainlen),2);
  1329. return $path;
  1330. }
  1331. }
  1332. /**
  1333. * 判断模块是否安装
  1334. * @param $m 模块名称
  1335. */
  1336. function module_exists($m = '') {
  1337. if ($m=='admin') return true;
  1338. $modules = getcache('modules', 'commons');
  1339. $modules = array_keys($modules);
  1340. return in_array($m, $modules);
  1341. }
  1342. /**
  1343. * 生成SEO
  1344. * @param $siteid 站点ID
  1345. * @param $catid 栏目ID
  1346. * @param $title 标题
  1347. * @param $description 描述
  1348. * @param $keyword 关键词
  1349. */
  1350. function seo($siteid, $catid = '', $title = '', $description = '', $keyword = '') {
  1351. if (!empty($title))$title = strip_tags($title);
  1352. if (!empty($description)) $description = strip_tags($description);
  1353. if (!empty($keyword)) $keyword = str_replace(' ', ',', strip_tags($keyword));
  1354. $sites = getcache('sitelist', 'commons');
  1355. $site = $sites[$siteid];
  1356. $cat = array();
  1357. if (!empty($catid)) {
  1358. $siteids = getcache('category_content','commons');
  1359. $siteid = $siteids[$catid];
  1360. $categorys = getcache('category_content_'.$siteid,'commons');
  1361. $cat = $categorys[$catid];
  1362. $cat['setting'] = string2array($cat['setting']);
  1363. }
  1364. $seo['site_title'] =isset($site['site_title']) && !empty($site['site_title']) ? $site['site_title'] : $site['name'];
  1365. $seo['keyword'] = !empty($keyword) ? $keyword : $site['keywords'];
  1366. $seo['description'] = isset($description) && !empty($description) ? $description : (isset($cat['setting']['meta_description']) && !empty($cat['setting']['meta_description']) ? $cat['setting']['meta_description'] : (isset($site['description']) && !empty($site['description']) ? $site['description'] : ''));
  1367. $seo['title'] = (isset($title) && !empty($title) ? $title.' - ' : '').(isset($cat['setting']['meta_title']) && !empty($cat['setting']['meta_title']) ? $cat['setting']['meta_title'].' - ' : (isset($cat['catname']) && !empty($cat['catname']) ? $cat['catname'].' - ' : ''));
  1368. foreach ($seo as $k=>$v) {
  1369. $seo[$k] = str_replace(array("\n","\r"), '', $v);
  1370. }
  1371. return $seo;
  1372. }
  1373. /**
  1374. * 获取站点的信息
  1375. * @param $siteid 站点ID
  1376. */
  1377. function siteinfo($siteid) {
  1378. static $sitelist;
  1379. if (empty($sitelist)) $sitelist = getcache('sitelist','commons');
  1380. return isset($sitelist[$siteid]) ? $sitelist[$siteid] : '';
  1381. }
  1382. /**
  1383. * 生成CNZZ统计代码
  1384. */
  1385. function tjcode() {
  1386. if(!module_exists('cnzz')) return false;
  1387. $config = getcache('cnzz', 'commons');
  1388. if (empty($config)) {
  1389. return false;
  1390. } else {
  1391. return '<script src=\'http://pw.cnzz.com/c.php?id='.$config['siteid'].'&l=2\' language=\'JavaScript\' charset=\'gb2312\'></script>';
  1392. }
  1393. }
  1394. /**
  1395. * 生成标题样式
  1396. * @par…

Large files files are truncated, but you can click here to view the full file