优化DedeCMS搜索结果

2017-04-13 14:28:28 dedecms

由于DedeCMS搜索采用了分词,提升了搜索智能化,但是我们发现,搜索结果并没有变的更准确,本篇对DedeCMS的搜索进行一个优化,使它的搜索结果变的更智能、准确。

首先需要调整搜索页面的一个栏目关键词替换,找到/plus/search.php将其中58行代码:

<pre

 class="brush:php;"> foreach($typeArr as $id=>$typename) { $keywordn = str_replace($typename, ' ', $keyword); if($keyword != $keywordn) {

修改为:

1 foreach($typeArr as $id=>$typename) 2 { 3     //$keywordn = str_replace($typename, ' ', $keyword); 4     $keywordn $keyword; 5     if($keyword != $keywordn) 6     {

然后,我们再调整下分词检索的类,找到/include/arc.searchview.class.php,找到

function GetKeywords($keyword)这个类的方法,替换为:

01 function GetKeywords($keyword) 02 { 03     global $cfg_soft_lang; 04     $keyword = cn_substr($keyword, 50); 05     $row $this->dsql->GetOne("SELECT spwords FROM ` <a href="http://www.mb5u.com/cmsmoban/dedecmsmoban/" style="background-image: none; border: none; padding: 0px; margin: 0px; text-decoration: none; color: rgb(0, 144, 206); background-position: initial initial; background-repeat: initial initial;">dede</a> _search_keywords` WHERE keyword='".addslashes($keyword)."'; "); 06     if(!is_array($row)) 07     { 08         if(strlen($keyword)>7) 09         { 10             $sp new SplitWord($cfg_soft_lang$cfg_soft_lang); 11             $sp->SetSource($keyword$cfg_soft_lang$cfg_soft_lang); 12             $sp->SetResultType(2); 13             $sp->StartAnalysis(TRUE); 14             $keywords $sp->GetFinallyResult(); 15             $idx_keywords $sp->GetFinallyIndex(); 16             ksort($idx_keywords); 17             $keywords $keyword.' '; 18             foreach ($idx_keywords as $key => $value) { 19                 if (strlen($key) <= 3) { 20                     continue; 21                 } 22                 $keywords .= ' '.$key; 23             } 24             $keywords = preg_replace("/[ ]{1,}/"" "$keywords); 25             //var_dump($idx_keywords);exit(); 26             unset($sp); 27         } 28         else 29         { 30             $keywords $keyword; 31         } 32         $inquery = "INSERT INTO `dede_search_keywords`(`keyword`,`spwords`,`count`, `result`,`lasttime`) 33       VALUES ('".addslashes($keyword)."''".addslashes($keywords)."''1''0','".time()."'); "; 34         $this->dsql->ExecuteNoneQuery($inquery); 35     } 36     else 37     { 38         $this->dsql->ExecuteNoneQuery("UPDATE `dede_search_keywords` SET count=count+1, lasttime='".time()."' WHERE keyword='".addslashes($keyword)."'; "); 39         $keywords $row['spwords']; 40     } 41     return $keywords; 42 }

最后,我们清空下数据表dede_search_keywords,重新构建检索分词结果,我们可以通过下面页面查看下分词的结果:http://www.cit.cn/plus/search.php?q=cit%D0%C5%CF%A2%CD%F8&searchtype=title

我们还会继续对DedeCMS搜索结果进行优化。