国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

651 lines
27KB

  1. <?php
  2. if (!defined('DEDEINC')) exit('dedebiz');
  3. /**
  4. * 系统核心函数存放文件
  5. *
  6. * @version $id:common.func.php 4 16:39 2010年7月6日 tianya $
  7. * @package DedeBIZ.Libraries
  8. * @copyright Copyright (c) 2022 DedeBIZ.COM
  9. * @license https://www.dedebiz.com/license
  10. * @link https://www.dedebiz.com
  11. */
  12. //显示类似Bootstrap警告框
  13. define('ALERT_PRIMARY', 1);
  14. define('ALERT_SECONDARY', 2);
  15. define('ALERT_SUCCESS', 3);
  16. define('ALERT_DANGER', 4);
  17. define('ALERT_WARNING', 5);
  18. define('ALERT_INFO', 6);
  19. define('ALERT_LIGHT', 7);
  20. define('ALERT_DARK', 8);
  21. define('ALERT_COLORS', array(
  22. ALERT_PRIMARY => array('#cfe2ff','#b6d4fe','#084298'),
  23. ALERT_SECONDARY => array('#e2e3e5','#d3d6d8','#41464b'),
  24. ALERT_SUCCESS => array('#d1e7dd','#badbcc','#0f5132'),
  25. ALERT_DANGER => array('#f8d7da','#f5c2c7','#842029'),
  26. ALERT_WARNING => array('#fff3cd','#ffecb5','#664d03'),
  27. ALERT_INFO => array('#cff4fc','#b6effb','#055160'),
  28. ALERT_LIGHT => array('#fefefe','#fdfdfe','#636464'),
  29. ALERT_DARK => array('#d3d3d4','#bcbebf','#141619'),
  30. ));
  31. define("ALERT_TPL", '<div style="position:relative;padding:.75rem 1.25rem;width:auto;font-size:12px;color:~color~;background:~background~;border-color:~border~;border:1px solid transparent;border-radius:.2rem">~content~</div>');
  32. //$content:文档,$type:alert类型
  33. function DedeAlert($content, $type = ALERT_PRIMARY, $isHTML=false)
  34. {
  35. $content = $isHTML? RemoveXSS($content) : htmlspecialchars($content);
  36. $colors = isset(ALERT_COLORS[$type])? ALERT_COLORS[$type] : ALERT_COLORS[ALERT_PRIMARY];
  37. list($background, $border, $color) = $colors;
  38. return str_replace(array('~color~','~background~','~border~', '~content~'),array($color,$background,$border,$content),ALERT_TPL);
  39. }
  40. if (version_compare(PHP_VERSION, '7.0.0', '>=')) {
  41. if (!function_exists('mysql_connect') and function_exists('mysqli_connect')) {
  42. function mysql_connect($server, $username, $password)
  43. {
  44. return mysqli_connect($server, $username, $password);
  45. }
  46. }
  47. if (!function_exists('mysql_query') and function_exists('mysqli_query')) {
  48. function mysql_query($query, $link)
  49. {
  50. return mysqli_query($link, $query);
  51. }
  52. }
  53. if (!function_exists('mysql_select_db') and function_exists('mysqli_select_db')) {
  54. function mysql_select_db($database_name, $link)
  55. {
  56. return mysqli_select_db($link, $database_name);
  57. }
  58. }
  59. if (!function_exists('mysql_fetch_array') and function_exists('mysqli_fetch_array')) {
  60. function mysql_fetch_array($result)
  61. {
  62. return mysqli_fetch_array($result);
  63. }
  64. }
  65. if (!function_exists('mysql_close') and function_exists('mysqli_close')) {
  66. function mysql_close($link)
  67. {
  68. return mysqli_close($link);
  69. }
  70. }
  71. if (!function_exists('mysql_free_result') and function_exists('mysqli_free_result')) {
  72. function mysql_free_result($result)
  73. {
  74. return mysqli_free_result($result);
  75. }
  76. }
  77. if (!function_exists('split')) {
  78. function split($pattern, $string)
  79. {
  80. return explode($pattern, $string);
  81. }
  82. }
  83. }
  84. //一个支持在PHP Cli Server打印的方法
  85. function var_dump_cli($val,...$values)
  86. {
  87. ob_start();
  88. var_dump($val,$values);
  89. error_log(ob_get_clean(), 4);
  90. }
  91. function get_mime_type($filename)
  92. {
  93. if (!function_exists('finfo_open')) {
  94. return 'unknow/octet-stream';
  95. }
  96. $finfo = finfo_open(FILEINFO_MIME_TYPE);
  97. $mimeType = finfo_file($finfo, $filename);
  98. finfo_close($finfo);
  99. return $mimeType;
  100. }
  101. function is_all_numeric(array $array)
  102. {
  103. foreach ($array as $item) {
  104. if (!is_numeric($item)) return false;
  105. }
  106. return true;
  107. }
  108. function make_hash()
  109. {
  110. $rand = dede_random_bytes(16);
  111. $_SESSION['token'] = ($rand === FALSE) ? md5(uniqid(mt_rand(), TRUE)) : bin2hex($rand);
  112. return $_SESSION['token'];
  113. }
  114. function dede_random_bytes($length)
  115. {
  116. if (empty($length) or !ctype_digit((string) $length)) {
  117. return FALSE;
  118. }
  119. if (function_exists('openssl_random_pseudo_bytes')) {
  120. return openssl_random_pseudo_bytes($length);
  121. }
  122. if (function_exists('random_bytes')) {
  123. try {
  124. return random_bytes((int) $length);
  125. } catch (Exception $e) {
  126. return FALSE;
  127. }
  128. }
  129. if (is_readable('/dev/urandom') && ($fp = fopen('/dev/urandom', 'rb')) !== FALSE) {
  130. version_compare(PHP_VERSION, '5.4.0', '>=') && stream_set_chunk_size($fp, $length);
  131. $output = fread($fp, $length);
  132. fclose($fp);
  133. if ($output !== FALSE) {
  134. return $output;
  135. }
  136. }
  137. return FALSE;
  138. }
  139. //SQL语句过滤程序,由80sec提供,这里作了适当的修改
  140. if (!function_exists('CheckSql')) {
  141. function CheckSql($db_string, $querytype = 'select')
  142. {
  143. global $cfg_cookie_encode;
  144. $clean = '';
  145. $error = '';
  146. $old_pos = 0;
  147. $pos = -1;
  148. $enkey = substr(md5(substr($cfg_cookie_encode.'dedebiz', 0, 5)), 0, 10);
  149. $log_file = DEDEDATA.'/checksql_'.$enkey.'_safe.txt';
  150. $userIP = GetIP();
  151. $getUrl = GetCurUrl();
  152. //如果是普通查询语句,直接过滤一些特殊语法
  153. if ($querytype == 'select') {
  154. $notallow1 = "[^0-9a-z@\._-]{1,}(union|sleep|benchmark|load_file|outfile)[^0-9a-z@\.-]{1,}";
  155. if (preg_match("/".$notallow1."/i", $db_string)) {
  156. fputs(fopen($log_file, 'a+'), "$userIP||$getUrl||$db_string||SelectBreak\r\n");
  157. exit("<span>Safe Alert: Request Error step 1 !</span>");
  158. }
  159. }
  160. //完整的SQL检查
  161. while (TRUE) {
  162. $pos = strpos($db_string, '\'', $pos + 1);
  163. if ($pos === FALSE) {
  164. break;
  165. }
  166. $clean .= substr($db_string, $old_pos, $pos - $old_pos);
  167. while (TRUE) {
  168. $pos1 = strpos($db_string, '\'', $pos + 1);
  169. $pos2 = strpos($db_string, '\\', $pos + 1);
  170. if ($pos1 === FALSE) {
  171. break;
  172. } elseif ($pos2 == FALSE || $pos2 > $pos1) {
  173. $pos = $pos1;
  174. break;
  175. }
  176. $pos = $pos2 + 1;
  177. }
  178. $clean .= '$s$';
  179. $old_pos = $pos + 1;
  180. }
  181. $clean .= substr($db_string, $old_pos);
  182. $clean = trim(strtolower(preg_replace(array('~\s+~s'), array(' '), $clean)));
  183. if (
  184. strpos($clean, '@') !== FALSE or strpos($clean, 'char(') !== FALSE or strpos($clean, '"') !== FALSE
  185. or strpos($clean, '$s$$s$') !== FALSE
  186. ) {
  187. $fail = TRUE;
  188. if (preg_match("#^create table#i", $clean)) $fail = FALSE;
  189. $error = "unusual character";
  190. }
  191. //老版本的Mysql并不支持union,常用的程序里也不使用union,但是一些黑客使用它,所以检查它
  192. if (strpos($clean, 'union') !== FALSE && preg_match('~(^|[^a-z])union($|[^[a-z])~s', $clean) != 0) {
  193. $fail = TRUE;
  194. $error = "union detect";
  195. }
  196. //发布版本的程序可能比较少包括--,#这样的注释,但是黑客经常使用它们
  197. elseif (strpos($clean, '/*') > 2 || strpos($clean, '--') !== FALSE || strpos($clean, '#') !== FALSE) {
  198. $fail = TRUE;
  199. $error = "comment detect";
  200. }
  201. //这些函数不会被使用,但是黑客会用它来操作文件,down掉数据库
  202. elseif (strpos($clean, 'sleep') !== FALSE && preg_match('~(^|[^a-z])sleep($|[^[a-z])~s', $clean) != 0) {
  203. $fail = TRUE;
  204. $error = "slown down detect";
  205. } elseif (strpos($clean, 'benchmark') !== FALSE && preg_match('~(^|[^a-z])benchmark($|[^[a-z])~s', $clean) != 0) {
  206. $fail = TRUE;
  207. $error = "slown down detect";
  208. } elseif (strpos($clean, 'load_file') !== FALSE && preg_match('~(^|[^a-z])load_file($|[^[a-z])~s', $clean) != 0) {
  209. $fail = TRUE;
  210. $error = "file fun detect";
  211. } elseif (strpos($clean, 'into outfile') !== FALSE && preg_match('~(^|[^a-z])into\s+outfile($|[^[a-z])~s', $clean) != 0) {
  212. $fail = TRUE;
  213. $error = "file fun detect";
  214. }
  215. //老版本的MYSQL不支持子查询,我们的程序里可能也用得少,但是黑客可以使用它来查询数据库敏感信息
  216. elseif (preg_match('~\([^)]*?select~s', $clean) != 0) {
  217. $fail = TRUE;
  218. $error = "sub select detect";
  219. }
  220. if (!empty($fail)) {
  221. fputs(fopen($log_file, 'a+'), "$userIP||$getUrl||$db_string||$error\r\n");
  222. exit("<span>Safe Alert: Request Error step 2!</span>");
  223. } else {
  224. return $db_string;
  225. }
  226. }
  227. }
  228. /**
  229. * 载入小助手,系统默认载入小助手
  230. * 在/data/helper.inc.php中进行默认小助手初始化的设置,创建一个示例为test.helper.php文件基本文档如下:
  231. * <code>
  232. * if (!function_exists('HelloDede'))
  233. * {
  234. * function HelloDede()
  235. * {
  236. * echo "Hello! Dede";
  237. * }
  238. * }
  239. * </code>
  240. * 则我们在开发中使用这个小助手的时候直接使用函数helper('test');初始化它,然后在文件中就可以直接使用:HelloDede();来进行调用
  241. *
  242. * @access public
  243. * @param mix $helpers 小助手名称,可以是数组,可以是单个字符串
  244. * @return void
  245. */
  246. $_helpers = array();
  247. function helper($helpers)
  248. {
  249. //如果是数组,则进行递归操作
  250. if (is_array($helpers)) {
  251. foreach ($helpers as $dede) {
  252. helper($dede);
  253. }
  254. return;
  255. }
  256. if (isset($_helpers[$helpers])) {
  257. return;
  258. }
  259. if (file_exists(DEDEINC.'/helpers/'.$helpers.'.helper.php')) {
  260. include_once(DEDEINC.'/helpers/'.$helpers.'.helper.php');
  261. $_helpers[$helpers] = TRUE;
  262. }
  263. //无法载入小助手
  264. if (!isset($_helpers[$helpers])) {
  265. exit('Unable to load the requested file: helpers/'.$helpers.'.helper.php');
  266. }
  267. }
  268. function dede_htmlspecialchars($str)
  269. {
  270. global $cfg_soft_lang;
  271. if (version_compare(PHP_VERSION, '5.4.0', '<')) return htmlspecialchars($str);
  272. if ($cfg_soft_lang == 'gb2312') return htmlspecialchars($str, ENT_COMPAT, 'ISO-8859-1');
  273. else return htmlspecialchars($str);
  274. }
  275. /**
  276. * 载入小助手,这里会员可能载入用helps载入多个小助手
  277. *
  278. * @access public
  279. * @param string
  280. * @return string
  281. */
  282. function helpers($helpers)
  283. {
  284. helper($helpers);
  285. }
  286. //兼容php4的file_put_contents
  287. if (!function_exists('file_put_contents')) {
  288. function file_put_contents($n, $d)
  289. {
  290. $f = @fopen($n, "w");
  291. if (!$f) {
  292. return FALSE;
  293. } else {
  294. fwrite($f, $d);
  295. fclose($f);
  296. return TRUE;
  297. }
  298. }
  299. }
  300. /**
  301. * 显示更新信息
  302. *
  303. * @return void
  304. */
  305. function UpdateStat()
  306. {
  307. include_once(DEDEINC."/inc/inc_stat.php");
  308. return SpUpdateStat();
  309. }
  310. $arrs1 = array();
  311. $arrs2 = array();
  312. /**
  313. * 短消息函数,可以在某个动作处理后友好的系统提示
  314. *
  315. * @param string $msg 消息系统提示
  316. * @param string $gourl 跳转地址
  317. * @param int $onlymsg 仅显示信息
  318. * @param int $limittime 限制时间
  319. * @return void
  320. */
  321. function ShowMsg($msg, $gourl, $onlymsg = 0, $limittime = 0)
  322. {
  323. if (isset($GLOBALS['format']) && strtolower($GLOBALS['format'])==='json') {
  324. echo json_encode(array(
  325. "code"=>0,
  326. "msg"=>$msg,
  327. "gourl"=>$gourl,
  328. ));
  329. return;
  330. }
  331. if (empty($GLOBALS['cfg_plus_dir'])) $GLOBALS['cfg_plus_dir'] = '..';
  332. $htmlhead = "<!DOCTYPE html><html><head><meta charset='utf-8'><meta http-equiv='X-UA-Compatible' content='IE=Edge,chrome=1'><title>系统提示</title><base target='_self'></head><body><script>";
  333. $htmlfoot = "</script></body></html>";
  334. $litime = ($limittime == 0 ? 1000 : $limittime);
  335. $func = '';
  336. if ($gourl == '-1') {
  337. if ($limittime == 0) $litime = 5000;
  338. $gourl = "javascript:history.go(-1);";
  339. }
  340. if ($gourl == '' || $onlymsg == 1) {
  341. $msg = "<script>alert(\"".str_replace("\"", "“", $msg)."\");</script>";
  342. } else {
  343. //当网址为:close::objname时,关闭父框架的id=objname元素
  344. if (preg_match('/close::/', $gourl)) {
  345. $tgobj = trim(preg_replace('/close::/', '', $gourl));
  346. $gourl = 'javascript:;';
  347. $func .= "window.parent.document.getElementById('{$tgobj}').style.display='none';\r\n";
  348. }
  349. $func .= "var pgo=0;function JumpUrl(){if (pgo==0){location='$gourl'; pgo=1;}}";
  350. $rmsg = $func;
  351. $rmsg .= "document.write(\"<style>body{margin:0;line-height:1.6;letter-spacing:.6px;font:14px Helvetica Neue,Helvetica,PingFang SC,Tahoma,Arial,sans-serif;color:#545b62;background:#f5f5f5}a{color:#1eb867;text-decoration:none}.tips-box{margin:70px auto 0;width:500px;height:auto;background:#fff;border-radius:.2rem;box-shadow:0 .125rem .25rem rgba(0,0,0,.075)}.tips-head{margin:0 20px;padding:18px 0;border-bottom:1px solid #f5f5f5}.tips-head p{margin:0;padding-left:10px;line-height:16px;text-align:left;border-left:3px solid #dc3545}.tips-body{padding:20px;min-height:130px;color:#545b62}.btn{margin-top:20px;text-align:center}.btn a{display:inline-block;padding:.375rem .75rem;font-size:12px;color:#fff;background:#1eb867;border-radius:.2rem;text-align:center;transition:all .3s}.btn a:focus{background:#006829;border-color:#005b24;box-shadow:0 0 0 0.2rem rgba(72,180,97,.5)}.text-primary{color:#007bff}@media (max-width:768px){.tips{padding:0 15px}.tips,.tips-box{width:100%}}</style>\");";
  352. $rmsg .= "document.write(\"<div class='tips'><div class='tips-box'><div class='tips-head'><p>系统提示</p></div>\");";
  353. $rmsg .= "document.write(\"<div class='tips-body'>\");";
  354. $rmsg .= "document.write(\"".str_replace("\"", "“", $msg)."\");";
  355. $rmsg .= "document.write(\"";
  356. if ($onlymsg == 0) {
  357. if ($gourl != 'javascript:;' && $gourl != '') {
  358. $rmsg .= "<div class='btn'><a href='{$gourl}'>点击反应</a></div>\");";
  359. $rmsg .= "setTimeout('JumpUrl()',$litime);";
  360. } else {
  361. $rmsg .= "</div>\");";
  362. }
  363. } else {
  364. $rmsg .= "</div></div>\");";
  365. }
  366. $msg = $htmlhead.$rmsg.$htmlfoot;
  367. }
  368. echo $msg;
  369. }
  370. /**
  371. * 表中是否存在某个字段
  372. *
  373. * @param mixed $tablename 表名称
  374. * @param mixed $field 字段名
  375. * @return void
  376. */
  377. function TableHasField($tablename,$field)
  378. {
  379. global $dsql;
  380. $dsql->GetTableFields($tablename,"tfd");
  381. while ($r = $dsql->GetFieldObject("tfd")) {
  382. if ($r->name === $field) {
  383. return true;
  384. }
  385. }
  386. return false;
  387. }
  388. function GetSimpleServerSoftware()
  389. {
  390. if (preg_match("#^php#i",$_SERVER["SERVER_SOFTWARE"])) {
  391. return 'PHP Server';
  392. } else if (preg_match("#^apache#i",$_SERVER["SERVER_SOFTWARE"])){
  393. return 'Apache';
  394. } else if (preg_match("#^nginx#i",$_SERVER["SERVER_SOFTWARE"])){
  395. return 'Nginx';
  396. } else if (preg_match("#^microsoft-iis#i",$_SERVER["SERVER_SOFTWARE"])){
  397. return 'IIS';
  398. } else if (preg_match("#^caddy#i",$_SERVER["SERVER_SOFTWARE"])){
  399. return 'Caddy';
  400. } else {
  401. return 'Other';
  402. }
  403. }
  404. /**
  405. * 获取验证码的session值
  406. *
  407. * @return string
  408. */
  409. function GetCkVdValue()
  410. {
  411. @session_id($_COOKIE['PHPSESSID']);
  412. @session_start();
  413. return isset($_SESSION['securimage_code_value']) ? $_SESSION['securimage_code_value'] : '';
  414. }
  415. /**
  416. * PHP某些版本有Bug,不能在同一作用域中同时读session并改注销它,因此调用后需执行本函数
  417. *
  418. * @return void
  419. */
  420. function ResetVdValue()
  421. {
  422. @session_start();
  423. $_SESSION['securimage_code_value'] = '';
  424. }
  425. function IndexSub($idx, $num)
  426. {
  427. return intval($idx) - intval($num) == 0 ? '0 ' : intval($idx) - intval($num);
  428. }
  429. //用来返回index的active
  430. function IndexActive($idx)
  431. {
  432. if ($idx == 1) {
  433. return ' active';
  434. } else {
  435. return '';
  436. }
  437. }
  438. //是否是HTTPS
  439. function IsSSL()
  440. {
  441. if (@$_SERVER['HTTPS'] && ('1' == $_SERVER['HTTPS'] || 'on' == strtolower($_SERVER['HTTPS']))) {
  442. return true;
  443. } elseif ('https' == @$_SERVER['REQUEST_SCHEME']) {
  444. return true;
  445. } elseif ('443' == $_SERVER['SERVER_PORT']) {
  446. return true;
  447. } elseif ('https' == @$_SERVER['HTTP_X_FORWARDED_PROTO']) {
  448. return true;
  449. }
  450. return false;
  451. }
  452. //获取对应版本号的更新SQL
  453. function GetUpdateSQL()
  454. {
  455. global $cfg_dbprefix, $cfg_dbtype, $cfg_db_language;
  456. $result = array();
  457. $query = '';
  458. $sql4tmp = "ENGINE=MyISAM DEFAULT CHARSET=".$cfg_db_language;
  459. $fp = fopen(DEDEROOT.'/install/update.txt','r');
  460. $sqls = array();
  461. $current_ver = "";
  462. while(!feof($fp))
  463. {
  464. $line = rtrim(fgets($fp,1024));
  465. if (preg_match("/\-\- ([\d\.]+)/",$line,$matches)) {
  466. if (count($sqls) > 0) {
  467. $result[$current_ver] = $sqls;
  468. }
  469. $sqls = array();
  470. $current_ver = $matches[1];
  471. }
  472. if (preg_match("#;$#", $line)) {
  473. $query .= $line."\n";
  474. $query = str_replace('#@__',$cfg_dbprefix,$query);
  475. if ($cfg_dbtype == 'sqlite') {
  476. $query = preg_replace('/character set (.*?) /i','',$query);
  477. $query = preg_replace('/unsigned/i','',$query);
  478. $query = str_replace('TYPE=MyISAM','',$query);
  479. $query = preg_replace ('/TINYINT\(([\d]+)\)/i','INTEGER',$query);
  480. $query = preg_replace ('/mediumint\(([\d]+)\)/i','INTEGER',$query);
  481. $query = preg_replace ('/smallint\(([\d]+)\)/i','INTEGER',$query);
  482. $query = preg_replace('/int\(([\d]+)\)/i','INTEGER',$query);
  483. $query = preg_replace('/auto_increment/i','PRIMARY KEY AUTOINCREMENT',$query);
  484. $query = preg_replace('/,([\t\s ]+)KEY(.*?)MyISAM;/','',$query);
  485. $query = preg_replace('/,([\t\s ]+)KEY(.*?);/',');',$query);
  486. $query = preg_replace('/,([\t\s ]+)UNIQUE KEY(.*?);/',');',$query);
  487. $query = preg_replace('/set\(([^\)]*?)\)/','varchar',$query);
  488. $query = preg_replace('/enum\(([^\)]*?)\)/','varchar',$query);
  489. if (preg_match("/PRIMARY KEY AUTOINCREMENT/",$query)) {
  490. $query = preg_replace('/,([\t\s ]+)PRIMARY KEY([\t\s ]+)\(`([0-9a-zA-Z]+)`\)/i','',$query);
  491. }
  492. $sqls[] = $query;
  493. } else {
  494. if (preg_match('#CREATE#i', $query)) {
  495. $sqls[] = preg_replace("#TYPE=MyISAM#i",$sql4tmp,$query);
  496. } else {
  497. $sqls[] = $query;
  498. }
  499. }
  500. $query='';
  501. } else if (!preg_match("#^(\/\/|--)#", $line)) {
  502. $query .= $line;
  503. }
  504. }
  505. if (count($sqls) > 0) {
  506. $result[$current_ver] = $sqls;
  507. }
  508. fclose($fp);
  509. return $result;
  510. }
  511. //标签调用标签[field:id function='GetMyTags(@me,2)'/]2表示输出2个文档
  512. if (!function_exists('GetMyTags')) {
  513. function GetMyTags($aid, $num=3)
  514. {
  515. global $dsql, $cfg_cmspath;
  516. $tags = '';
  517. $query = "SELECT * FROM `#@__taglist` WHERE aid='$aid' LIMIT $num";
  518. $dsql->Execute('tag',$query);
  519. while($row = $dsql->GetArray('tag')) {
  520. $link = $cfg_cmspath."/apps/tags.php?/{$row['tid']}";
  521. $tags.= ($tags==''?"<a href='{$link}'>{$row['tag']}</a>" : "<a href='{$link}'>{$row['tag']}</a>");
  522. }
  523. return $tags;
  524. }
  525. }
  526. /*会员中心调用默认模板<?php pasterTempletDiy('head.htm');?>*/
  527. if (!function_exists('pasterTempletDiy')) {
  528. function pasterTempletDiy($path)
  529. {
  530. global $cfg_basedir, $cfg_templets_dir, $cfg_df_style;
  531. $tmpfile = $cfg_basedir.$cfg_templets_dir.'/'.$cfg_df_style.'/'.$path;
  532. $dtp = new PartView();
  533. $dtp->SetTemplet($tmpfile);
  534. $dtp->Display();
  535. }
  536. }
  537. //联动单筛选标签{dede:php}AddFilter(模型id,类型,'字段1,字段2');{/dede:php}
  538. function litimgurls($imgid = 0)
  539. {
  540. global $lit_imglist, $dsql;
  541. $row = $dsql->GetOne("SELECT c.addtable FROM `#@__archives` AS a LEFT JOIN `#@__channeltype` AS c ON a.channel=c.id WHERE a.id='$imgid'");
  542. $addtable = trim($row['addtable']);
  543. $row = $dsql->GetOne("SELECT imgurls FROM `$addtable` WHERE aid='$imgid'");
  544. $ChannelUnit = new ChannelUnit(2, $imgid);
  545. $lit_imglist = $ChannelUnit->GetlitImgLinks($row['imgurls']);
  546. return $lit_imglist;
  547. }
  548. //联动单筛选字符过滤函数
  549. function string_filter($str, $stype = "inject")
  550. {
  551. if ($stype == "inject") {
  552. $str = str_replace(
  553. array("select", "insert", "update", "delete", "alter", "cas", "union", "into", "load_file", "outfile", "create", "join", "where", "like", "drop", "modify", "rename", "'", "/*", "*", "../", "./"),
  554. array("", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""),
  555. $str
  556. );
  557. } else if ($stype == "xss") {
  558. $farr = array("/\s+/", "/<(\/?)(script|META|STYLE|HTML|HEAD|BODY|STYLE |i?frame|b|strong|style|html|img|P|o:p|iframe|u|em|strike|BR|div|a|TABLE|TBODY|object|tr|td|st1:chsdate|FONT|span|MARQUEE|body|title|\r\n|link|meta|\?|\%)([^>]*?)>/isU", "/(<[^>]*)on[a-zA-Z]+\s*=([^>]*>)/isU",);
  559. $tarr = array(" ", "", "\\1\\2",);
  560. $str = preg_replace($farr, $tarr, $str);
  561. $str = str_replace(
  562. array("<", ">", "'", "\"", ";", "/*", "*", "../", "./"),
  563. array("&lt;", "&gt;", "", "", "", "", "", "", ""),
  564. $str
  565. );
  566. }
  567. return $str;
  568. }
  569. //联动单筛选发布三种类型
  570. function AddFilter($channelid, $type=1, $fieldsnamef=array(), $defaulttid=0, $toptid=0, $loadtype='autofield')
  571. {
  572. global $tid, $dsql, $id, $aid;
  573. $tid = $defaulttid ? $defaulttid : $tid;
  574. if ($id!="" || $aid!="") {
  575. $arcid = $id!="" ? $id : $aid;
  576. $tidsq = $dsql->GetOne("SELECT * FROM `#@__archives` WHERE id='$arcid'");
  577. $tid = $toptid==0 ? $tidsq["typeid"] : $tidsq["topid"];
  578. }
  579. $nofilter = (isset($_REQUEST['TotalResult']) ? "&TotalResult=".$_REQUEST['TotalResult'] : '').(isset($_REQUEST['PageNo']) ? "&PageNo=".$_REQUEST['PageNo'] : '');
  580. $filterarr = string_filter(stripos($_SERVER['REQUEST_URI'], "list.php?tid=") ? str_replace($nofilter, '', $_SERVER['REQUEST_URI']) : $GLOBALS['cfg_cmsurl']."/apps/list.php?tid=".$tid);
  581. $cInfos = $dsql->GetOne("SELECT * FROM `#@__channeltype` WHERE id='$channelid'");
  582. $fieldset=$cInfos['fieldset'];
  583. $dtp = new DedeTagParse();
  584. $dtp->SetNameSpace('field', '<', '>');
  585. $dtp->LoadSource($fieldset);
  586. $dede_addonfields = '';
  587. if (is_array($dtp->CTags)) {
  588. foreach($dtp->CTags as $tida=>$ctag)
  589. {
  590. $fieldsname = $fieldsnamef ? explode(",", $fieldsnamef) : explode(",", $ctag->GetName());
  591. if (($loadtype!='autofield' || ($loadtype=='autofield' && $ctag->GetAtt('autofield')==1)) && in_array($ctag->GetName(), $fieldsname)) {
  592. $href1 = explode($ctag->GetName().'=', $filterarr);
  593. $href2 = explode('&', $href1[1]);
  594. $fields_value = $href2[0];
  595. switch ($type) {
  596. case 1:
  597. $dede_addonfields .= (preg_match("/&".$ctag->GetName()."=/is",$filterarr,$regm) ? '<a href="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'" class="btn btn-outline-success btn-sm">全部</a>' : '<a href="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'" class="btn btn-success btn-sm">全部</a>');
  598. $addonfields_items = explode(",",$ctag->GetAtt('default'));
  599. for ($i=0; $i<count($addonfields_items); $i++)
  600. {
  601. $href = stripos($filterarr,$ctag->GetName().'=') ? str_replace("=".$fields_value,"=".urlencode($addonfields_items[$i]),$filterarr) : $filterarr.'&'.$ctag->GetName().'='.urlencode($addonfields_items[$i]);
  602. $dede_addonfields .= ($fields_value!=urlencode($addonfields_items[$i]) ? '<a title="'.$addonfields_items[$i].'" href="'.$href.'" class="btn btn-outline-success btn-sm">'.$addonfields_items[$i].'</a>' : '<a href="'.$href.'" class="btn btn-success btn-sm">'.$addonfields_items[$i].'</a>');
  603. }
  604. break;
  605. case 2:
  606. $dede_addonfields .= '<select name="filter'.$ctag->GetName().'" onchange="window.location=this.options[this.selectedIndex].value">
  607. '.'<option value="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'">全部</option>';
  608. $addonfields_items = explode(",",$ctag->GetAtt('default'));
  609. for ($i=0; $i<count($addonfields_items); $i++)
  610. {
  611. $href = stripos($filterarr,$ctag->GetName().'=') ? str_replace("=".$fields_value,"=".urlencode($addonfields_items[$i]),$filterarr) : $filterarr.'&'.$ctag->GetName().'='.urlencode($addonfields_items[$i]);
  612. $dede_addonfields .= '<option value="'.$href.'"'.($fields_value==urlencode($addonfields_items[$i]) ? ' selected="selected"' : '').'>'.$addonfields_items[$i].'</option>
  613. ';
  614. }
  615. $dede_addonfields .= '</select>
  616. ';
  617. break;
  618. case 3:
  619. $dede_addonfields .= (preg_match("/&".$ctag->GetName()."=/is",$filterarr,$regm) ? '<a href="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'"><input type="radio" name="filter'.$ctag->GetName().'" value="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'" onclick="window.location=this.value">全部</a>' : '<span><input type="radio" name="filter'.$ctag->GetName().'" checked="checked">全部</span>');
  620. $addonfields_items = explode(",",$ctag->GetAtt('default'));
  621. for ($i=0; $i<count($addonfields_items); $i++)
  622. {
  623. $href = stripos($filterarr,$ctag->GetName().'=') ? str_replace("=".$fields_value,"=".urlencode($addonfields_items[$i]),$filterarr) : $filterarr.'&'.$ctag->GetName().'='.urlencode($addonfields_items[$i]);
  624. $dede_addonfields .= ($fields_value!=urlencode($addonfields_items[$i]) ? '<a title="'.$addonfields_items[$i].'" href="'.$href.'"><input type="radio" name="filter'.$ctag->GetName().'" value="'.$href.'" onclick="window.location=this.value">'.$addonfields_items[$i].'</a>' : '<span><input type="radio" name="filter'.$ctag->GetName().'" checked="checked">'.$addonfields_items[$i].'</span>');
  625. }
  626. break;
  627. }
  628. }
  629. }
  630. }
  631. echo $dede_addonfields;
  632. }
  633. /**
  634. * HideEmail隐藏邮箱
  635. *
  636. * @param mixed $email
  637. * @return string
  638. */
  639. function HideEmail($email)
  640. {
  641. if (empty($email)) return "空";
  642. $em = explode("@",$email);
  643. $name = implode('@', array_slice($em, 0, count($em)-1));
  644. $len = floor(strlen($name)/2);
  645. return substr($name,0, $len).str_repeat('*', $len)."@".end($em);
  646. }
  647. //自定义函数接口
  648. if (file_exists(DEDEINC.'/extend.func.php')) {
  649. require_once(DEDEINC.'/extend.func.php');
  650. }
  651. ?>