phpcmsv9全站搜索,不限模型

phpcmsv9全站搜索,不限模型,今天又涨知识了。大家都知道,phpcms搜索时按照模型来搜索的,用了这个方法后,就可以全站搜索

简单修改一下v9默认的搜索功能,可以不按模型搜索全站内容

下面是被修改后的search模块中的index.php文件

<?php
defined('IN_PHPCMS') or exit('No permission resources.');
pc_base::load_sys_class('form','',0);
pc_base::load_sys_class('format','',0);
class index {
  function __construct() {
    $this->db = pc_base::load_model('search_model');
    $this->content_db = pc_base::load_model('content_model');
  }

  /**
   * 关键词搜索
   */
  public function init() {
    //获取siteid
    $siteid = isset($_REQUEST['siteid']) && trim($_REQUEST['siteid']) ? intval($_REQUEST['siteid']) : 1;
    $SEO = seo($siteid);

    //搜索配置
    $search_setting = getcache('search');
    $setting = $search_setting[$siteid];

    $search_model = getcache('search_model_'.$siteid);
    $type_module = getcache('type_module_'.$siteid);

    if(isset($_GET['q'])) {
      if(trim($_GET['q'])=='') {
        header('Location: '.APP_PATH.'index.php?m=search');exit;
      }
      $typeid = empty($_GET['typeid']) ? 0 : intval($_GET['typeid']);
      $time = empty($_GET['time']) || !in_array($_GET['time'],array('all','day','month','year','week')) ? 'all' : trim($_GET['time']);
      $page = isset($_GET['page']) ? intval($_GET['page']) : 1;
      $pagesize = 10;
      $q = safe_replace(trim($_GET['q']));
      $q = new_html_special_chars(strip_tags($q));
      $q = str_replace('%', '', $q);	//过滤'%',用户全文搜索
      $search_q = $q;	//搜索原内容

      $sql_time = $sql_tid = '';
      if($typeid) $sql_tid = ' AND typeid = '.$typeid;
      //按时间搜索
      if($time == 'day') {
        $search_time = SYS_TIME - 86400;
        $sql_time = ' AND adddate > '.$search_time;
      } elseif($time == 'week') {
        $search_time = SYS_TIME - 604800;
        $sql_time = ' AND adddate > '.$search_time;
      } elseif($time == 'month') {
        $search_time = SYS_TIME - 2592000;
        $sql_time = ' AND adddate > '.$search_time;
      } elseif($time == 'year') {
        $search_time = SYS_TIME - 31536000;
        $sql_time = ' AND adddate > '.$search_time;
      } else {
        $search_time = 0;
        $sql_time = '';
      }
      if($page==1 && !$setting['sphinxenable']) {
        //精确搜索
        $commend = $this->db->get_one("`siteid`= '$siteid' $sql_tid $sql_time AND `data` like '%$q%'");
      } else {
        $commend = '';
      }
      //如果开启sphinx
      if($setting['sphinxenable']) {
        $sphinx = pc_base::load_app_class('search_interface', '', 0);
        $sphinx = new search_interface();

        $offset = $pagesize*($page-1);
        $res = $sphinx->search($q, array($siteid), array($typeid), array($search_time, SYS_TIME), $offset, $pagesize, '@weight desc');
        $totalnums = $res['total'];
        //如果结果不为空
        if(!empty($res['matches'])) {
          $result = $res['matches'];
        }
      } else {

        $sql = "`siteid`= '$siteid' $sql_tid $sql_time AND `data` like '%$q%'";

        $result = $this->db->listinfo($sql, 'searchid DESC', $page, 10);
      }
       var_dump($result);
      //如果结果不为空
      if(!empty($result) || !empty($commend['id'])) {
        foreach($result as $_v) {
          if($_v['typeid']) $sids[$_v['typeid']][] = $_v['id'];
        }

        if(!empty($commend['id'])) {
          if($commend['typeid']) $sids[$commend['typeid']][] = $commend['id'];
        }
        $model_type_cache = getcache('type_model_'.$siteid,'search');
        $model_type_cache = array_flip($model_type_cache);
        $data = array();
        foreach($sids as $_k=>$_val) {
          $tid = $_k;
          $ids = array_unique($_val);

          $where = to_sqls($ids, '', 'id');
          //获取模型id
          $modelid = $model_type_cache[$tid];

          //是否读取其他模块接口
          if($modelid) {
            $this->content_db->set_model($modelid);

            /**
            * 如果表名为空,则为黄页模型
            */
            if(empty($this->content_db->model_tablename)) {
              $this->content_db = pc_base::load_model('yp_content_model');
              $this->content_db->set_model($modelid);

            }
            $datas = $this->content_db->select($where, '*');
          }
          $data = array_merge($data,$datas);
        }
        $pages = $this->db->pages;
        $totalnums = $this->db->number;

        //如果分词结果为空
        if(!empty($segment_q)) {
          $replace = explode(' ', $segment_q);
          foreach($replace as $replace_arr_v) {
            $replace_arr[] =  '<font color=red>'.$replace_arr_v.'</font>';
          }
          foreach($data as $_k=>$_v) {
            $data[$_k]['title'] = str_replace($replace, $replace_arr, $_v['title']);
            $data[$_k]['description'] = str_replace($replace, $replace_arr, $_v['description']);
          }
        } else {
          foreach($data as $_k=>$_v) {
            $data[$_k]['title'] = str_replace($q, '<font color=red>'.$q.'</font>', $_v['title']);
            $data[$_k]['description'] = str_replace($q, '<font color=red>'.$q.'</font>', $_v['description']);
          }
        }
      }
      $execute_time = execute_time();
      $pages = isset($pages) ? $pages : '';
      $totalnums = isset($totalnums) ? $totalnums : 0;
      $data = isset($data) ? $data : '';

      include	template('search','list');
    } else {
      include	template('search','index');
    }
  }

  public function public_get_suggest_keyword() {
    $url = $_GET['url'].'&q='.$_GET['q'];
    $trust_url = array('c8430fcf851e85818b546addf5bc4dd3');
    $urm_md5 = md5($url);
    if (!in_array($urm_md5, $trust_url)) exit;

    $res = @file_get_contents($url);
    if(CHARSET != 'gbk') {
      $res = iconv('gbk', CHARSET, $res);
    }
    echo $res;
  }

  /**
   * 提示搜索接口
   * TODO 暂时未启用,用的是google的接口
   */
  public function public_suggest_search() {
    //关键词转换为拼音
    pc_base::load_sys_func('iconv');
    $pinyin = gbk_to_pinyin($q);
    if(is_array($pinyin)) {
      $pinyin = implode('', $pinyin);
    }
    $this->keyword_db = pc_base::load_model('search_keyword_model');
    $suggest = $this->keyword_db->select("pinyin like '$pinyin%'", '*', 10, 'searchnums DESC');

    foreach($suggest as $v) {
      echo $v['keyword']."\n";
    }

  }
}
?>

然后在header.html模板(不在这里,就在其他的搜索框页面)上面增加一个“不限”的搜索条件,将typeid对应的值为0,search中的index.html和lists.html也做相同处理,效果就出来那,本文由程序员人生网www.wfuyu.com整理发布,这样只要不选择模型那么搜索出来的结果就是所有模型中符合条件的数据

时间: 2024-12-11 21:16:10

phpcmsv9全站搜索,不限模型的相关文章

ZKEACMS 全站搜索插件

ZKEACMS 全站搜索插件 让ZKEACMS支持搜索功能 数据库 Microstft Sql Server 2008R2 以上 页面的索引主要是运用了MsSql的全文索引,如果你还不了解全文索引,可以使用以下链接来了解全文索引的相关知识 https://docs.microsoft.com/zh-cn/sql/relational-databases/search/full-text-search 目前仅支持MsSql数据库,如果正好你不是使用MsSql数据库的话,也没有关系,它将很容易改造成

原创:史上对BM25模型最全面最深刻的解读以及lucene排序深入讲解(佟学强)

垂直搜索结果的优化包括对搜索结果的控制和排序优化两方面,其中排序又是重中之重.本文将全面深入探讨垂直搜索的排序模型的演化过程,最后推导出BM25模型的排序.然后将演示如何修改lucene的排序源代码,下一篇将深入解读目前比较火热的机器学习排序在垂直搜索中的应用.文章的结构如下: 一.VSM模型简单介绍: 二.lucene默认的评分公式介绍: 三.概率语言模型中的二元独立模型BIM介绍: 四.BM25介绍: 五.lucene中的edismax解析器介绍以及评分公式源代码介绍: 六.修改排序源代码:

记一次企业级爬虫系统升级改造(五):基于JieBaNet+Lucene.Net实现全文搜索

实现效果: 上一篇文章有附全文搜索结果的设计图,下面截一张开发完成上线后的实图: 基本风格是模仿的百度搜索结果,绿色的分页略显小清新. 目前已采集并创建索引的文章约3W多篇,索引文件不算太大,查询速度非常棒. 刀不磨要生锈,人不学要落后.每天都要学一些新东西. 基本技术介绍: 还记得上一次做全文搜索是在2013年,主要核心设计与代码均是当时的架构师写的,自己只能算是全程参与. 当时使用的是经典搭配:盘古分词+Lucene.net. 前几篇文章有说到,盘古分词已经很多年不更新了,我在Support

1.PHP站内搜索

PHP站内搜索:多关键字.加亮显示 1.SQL语句中的模糊查找 $sql = "SELECT * FROM `message` WHERE `content`like '%$k[0]%' and `content`like '%$k[0]%'"; 2.多个关键字搜索的原理和技巧 3.替换关键字高亮显示 $r[content] = preg_replace("/($_GET[key])/i", "<font color = red><b&g

详谈京东的商品搜索系统架构设计

京东商品搜索引擎是搜索推荐部自主研发的商品搜索引擎,主要功能是为海量京东用户提供精准.快速的购物体验.虽然只有短短几年的时间,我们的搜索引擎已经经过了多次618店庆和双11的考验,目前已经能够与人们日常使用的如谷歌.百度等全文搜索引擎相比,我们的产品与其有相通之处,比如涵盖亿级别商品的海量数据.支持短时超高并发查询.又有自己的业务特点: 海量的数据,亿级别的商品量: 高并发查询,日PV过亿: 请求需要快速响应. 搜索已经成为我们日常不可或缺的应用,很难想象没有了Google.百度等搜索引擎,互联

iOS开发项目篇—25字典转模型第三方框架、运行时机制简介

iOS开发项目篇—25字典转模型第三方框架.运行时机制简介 一.使用第三方框架完成字典转模型 1.获取框架 在www.code4app.com网站中,搜索字典转模型 可以点击下载代码进行下载,也可以带github上去下载. 管理框架的好处:点击刷新按钮会刷新所有的项目. 2.使用 1.导入第三方框架 2.使用示例 错误提示: 在刷新的时候直接使用一行代码即可: 1 /**加载最新微博数据*/ 2 -(void)loadNewStatus 3 { 4 //1.获得请求管理者 5 AFHTTPReq

TF-IDF模型的概率解释

信息检索概述 信息检索是当前应用十分广泛的一种技术,论文检索.搜索引擎都属于信息检索的范畴.通常,人们把信息检索问题抽象为:在文档集合D上,对于由关键词w[1] … w[k]组成的查询串q,返回一个按查询q和文档d匹配度relevance(q, d)排序的相关文档列表D’. 对于这一问题,先后出现了布尔模型.向量模型等各种经典的信息检索模型,它们从不同的角度提出了自己的一套解决方案.布尔模型以集合的布尔运算为基础,查询效率高,但模型过于简单,无法有效地对不同文档进行排序,查询效果不佳.向量模型把

ActorLite: 一个轻量级Actor模型实现

Actor模型 Actor模型为并行而生,具Wikipedia中的描述,它原本是为大量独立的微型处理器所构建的高性能网络而设计的模型.而目前,单台机器也有了多个独立的计算单元,这就是为什么在并行程序愈演愈烈的今天,Actor模型又重新回到了人们的视线之中了.Actor模型的理念非常简单:天下万物皆为Actor,Actor之间通过发送消息进行通信.Actor模型的执行方式有两个特点: 每个Actor,单线程地依次执行发送给它的消息. 不同的Actor可以同时执行它们的消息. 对于第1点至今还有一些

从排列到组合——深度优先搜索

前段时间在洛谷3.0上刷到一个题,让本人挠头了一段时间,RT: 题目描述 已知 n 个整数 x1,x2,-,xn,以及一个整数 k(k<n).从 n 个整数中任选 k 个整数相加,可分别得到一系列的和.例如当 n=4,k=3,4 个整数分别为 3,7,12,19 时,可得全部的组合与它们的和为: 3+7+12=22  3+7+19=29  7+12+19=38  3+12+19=34. 现在,要求你计算出和为素数共有多少种. 例如上例,只有一种的和为素数:3+7+19=29. 首先解决这个问题显