国内流行的内容管理系统(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.

93 lines
3.6KB

  1. <?php
  2. /**
  3. * 搜索页
  4. *
  5. * @version $id:search.php$
  6. * @package DedeBIZ.Site
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license https://www.dedebiz.com/license
  9. * @link https://www.dedebiz.com
  10. */
  11. require_once(dirname(__FILE__)."/../system/common.inc.php");
  12. require_once(DEDEINC."/archive/searchview.class.php");
  13. $pagesize = (isset($pagesize) && is_numeric($pagesize)) ? $pagesize : 10;
  14. $typeid = (isset($typeid) && is_numeric($typeid)) ? $typeid : 0;
  15. $channeltype = (isset($channeltype) && is_numeric($channeltype)) ? $channeltype : 0;
  16. $kwtype = (isset($kwtype) && is_numeric($kwtype)) ? $kwtype : 0;
  17. $mid = (isset($mid) && is_numeric($mid)) ? $mid : 0;
  18. unset($typeArr);
  19. if (!isset($orderby)) $orderby = '';
  20. else $orderby = preg_replace("#[^a-z]#i", '', $orderby);
  21. if (!isset($searchtype)) $searchtype = 'titlekeyword';
  22. else $searchtype = preg_replace("#[^a-z]#i", '', $searchtype);
  23. if (!isset($keyword)) {
  24. if (!isset($q)) $q = '';
  25. $keyword = $q;
  26. }
  27. $oldkeyword = $keyword = FilterSearch(stripslashes($keyword));
  28. //查找栏目信息
  29. if (empty($typeid)) {
  30. $typenameCacheFile = DEDEDATA.'/cache/typename.inc';
  31. if (!file_exists($typenameCacheFile) || filemtime($typenameCacheFile) < time() - (3600 * 24)) {
  32. $fp = fopen(DEDEDATA.'/cache/typename.inc', 'w');
  33. fwrite($fp, "<"."?php\r\n");
  34. $dsql->SetQuery("SELECT id,typename,channeltype FROM `#@__arctype`");
  35. $dsql->Execute();
  36. while ($row = $dsql->GetArray()) {
  37. fwrite($fp, "\$typeArr[{$row['id']}] = '{$row['typename']}';\r\n");
  38. }
  39. fwrite($fp, '?'.'>');
  40. fclose($fp);
  41. }
  42. //引入栏目缓存并看关键词是否有相关栏目文档
  43. require_once($typenameCacheFile);
  44. if (isset($typeArr) && is_array($typeArr)) {
  45. foreach ($typeArr as $id => $typename) {
  46. //$keywordn = str_replace($typename, ' ', $keyword);
  47. $keywordn = $keyword;
  48. if ($keyword != $keywordn) {
  49. $keyword = HtmlReplace($keywordn);
  50. $typeid = intval($id);
  51. break;
  52. }
  53. }
  54. }
  55. }
  56. $typeid = intval($typeid);
  57. $keyword = addslashes(cn_substr($keyword,30));
  58. $typeid = intval($typeid);
  59. if ($cfg_notallowstr != '' && preg_match("#".$cfg_notallowstr."#i", $keyword)) {
  60. ShowMsg("您的搜索关键词中存在非法文档,被系统禁止", "-1");
  61. exit();
  62. }
  63. if (($keyword == '' || strlen($keyword) < 2) && empty($typeid)) {
  64. ShowMsg('关键词不能小于2个字节', '-1');
  65. exit();
  66. }
  67. //检查搜索间隔时间
  68. $ip = GetIP();
  69. $now = time();
  70. $row = $dsql->GetOne("SELECT * FROM `#@__search_limits` WHERE ip='{$ip}'");
  71. if (is_array($row)) {
  72. if (($now - $row['searchtime']) < $cfg_search_time) {
  73. ShowMsg('管理员设定搜索时间间隔为'.$cfg_search_time.'秒,请稍后再试', '-1');
  74. exit;
  75. }
  76. $dsql->ExecuteNoneQuery("UPDATE `#@__search_limits` SET `searchtime`='{$now}' WHERE `ip`='{$ip}';");
  77. } else {
  78. $dsql->ExecuteNoneQuery("INSERT INTO `#@__search_limits` (`ip`, `searchtime`) VALUES ('{$ip}', '{$now}');");
  79. }
  80. //开始时间
  81. if (empty($starttime)) $starttime = -1;
  82. else {
  83. $starttime = (is_numeric($starttime) ? $starttime : -1);
  84. if ($starttime > 0) {
  85. $dayst = GetMkTime("2008-1-2 0:0:0") - GetMkTime("2008-1-1 0:0:0");
  86. $starttime = time() - ($starttime * $dayst);
  87. }
  88. }
  89. $t1 = ExecTime();
  90. $sp = new SearchView($typeid, $keyword, $orderby, $channeltype, $searchtype, $starttime, $pagesize, $kwtype, $mid);
  91. $keyword = $oldkeyword;
  92. $sp->Display();
  93. ?>