由于DedeCMS搜索采用了分词,提升了搜索智能化,但是我们发现,搜索结果并没有变的更准确,本篇对DedeCMS的搜索进行一个优化,使它的搜索结果变的更智能、准确。
首先需要调整搜索页面的一个栏目关键词替换,找到/plus/search.将其中58行:
foreach($typeArr as $id=>$typename) { $keywordn = str_replace($typename, ' ', $keyword); if($keyword != $keywordn) {修改为:
- foreach($typeArr as $id=>$typename)
- {
- //$keywordn = str_replace($typename, ' ', $keyword);
- $keywordn = $keyword;
- if($keyword != $keywordn)
- {
复制代码 然后,我们再调整下分词检索的类,找到/include/arc.searchview.class.php,找到function GetKeywords($keyword)这个类的方法,替换为:
- function GetKeywords($keyword)
- {
- global $cfg_soft_lang;
- $keyword = cn_substr($keyword, 50);
- $row = $this->dsql->GetOne("SELECT spwords FROM `[url=http://www.mb5u.com/cmsmoban/dedecmsmoban/]dede[/url]_search_keywords` WHERE keyword='".addslashes($keyword)."'; ");
- if(!is_array($row))
- {
- if(strlen($keyword)>7)
- {
- $sp = new SplitWord($cfg_soft_lang, $cfg_soft_lang);
- $sp->SetSource($keyword, $cfg_soft_lang, $cfg_soft_lang);
- $sp->SetResultType(2);
- $sp->StartAnalysis(TRUE);
- $keywords = $sp->GetFinallyResult();
- $idx_keywords = $sp->GetFinallyIndex();
- ksort($idx_keywords);
- $keywords = $keyword.' ';
- foreach ($idx_keywords as $key => $value) {
- if (strlen($key) dsql->ExecuteNoneQuery($inquery);
- }
- else
- {
- $this->dsql->ExecuteNoneQuery("UPDATE `dede_search_keywords` SET count=count+1,lasttime='".time()."' WHERE keyword='".addslashes($keyword)."'; ");
- $keywords = $row['spwords'];
- }
- return $keywords;
- }
复制代码 最后,我们清空下数据表dede_search_keywords,重新构建检索分词结果,我们可以通过下面页面查看下分词的结果:
我们还会继续对DedeCMS搜索结果进行优化。
|