-
玻璃制品廠家類網(wǎng)站織夢...
-
重工業(yè)機(jī)械鋼鐵類網(wǎng)站織...
-
戀愛情感資訊類網(wǎng)站織夢...
-
汽車銷售縱覽類網(wǎng)站織夢...
-
旅游公司類網(wǎng)站織夢模板...
-
金屬工藝品加工廠家類網(wǎng)...
-
汽車音箱喇叭低音炮類網(wǎng)...
-
齒輪設(shè)備類網(wǎng)站織夢模板...
-
蔬菜水果批發(fā)類網(wǎng)站織夢...
-
大理石瓷磚生產(chǎn)類網(wǎng)站織...
-
商用貨架展架類網(wǎng)站織夢...
-
家禽飼養(yǎng)基地類網(wǎng)站織夢...
-
花卉養(yǎng)殖資訊類網(wǎng)站織夢...
-
財富管理培訓(xùn)咨詢類網(wǎng)站...
-
室內(nèi)設(shè)計裝修工程類網(wǎng)站...
-
中英雙語建材瓷磚裝飾類...
-
壓濾機(jī)過濾設(shè)備類網(wǎng)站織...
-
網(wǎng)站優(yōu)化快速排名類科技...
-
創(chuàng)業(yè)資訊博客教程類網(wǎng)站...
-
電子產(chǎn)品營銷類網(wǎng)站織夢...
由于織夢DedeCMS搜索采用了分詞,提升了搜索智能化,但是我們發(fā)現(xiàn),搜索結(jié)果并沒有變的更準(zhǔn)確,
本篇對織夢源碼搜索進(jìn)行一個優(yōu)化,使它的搜索結(jié)果變的更智能、準(zhǔn)確。
首先打開/plus/search.php
找到
foreach($typeArr as $id=>$typename){$keywordn = str_replac($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 `dede_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) <= 3) {continue;}$keywords .= ' '.$key;}$keywords = preg_replace("/[ ]{1,}/", " ", $keywords);//var_dump($idx_keywords);exit();unset($sp);}else{$keywords = $keyword;}$inquery = "INSERT INTO `dede_search_keywords`(`keyword`,`spwords`,`count`,`result`,`lasttime`)VALUES ('".addslashes($keyword)."', '".addslashes($keywords)."', '1', '0', '".time()."'); ";$this->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;}


