-
鋼結(jié)構(gòu)崗?fù)I銷型織夢網(wǎng)...
-
食品百貨英文外貿(mào)類網(wǎng)站...
-
玩具動漫類網(wǎng)站織夢模板...
-
水利工程施工類網(wǎng)站織夢...
-
中英雙語律師事務(wù)所類網(wǎng)...
-
物流快運(yùn)速遞類網(wǎng)站織夢...
-
展覽展會信息類網(wǎng)站織夢...
-
蔬菜鮮果配送類網(wǎng)站織夢...
-
電腦系統(tǒng)軟件下載類網(wǎng)站...
-
儀器儀表科技公司類網(wǎng)站...
-
人力資源管理類網(wǎng)站織夢...
-
貂絨大衣服裝設(shè)計類網(wǎng)站...
-
網(wǎng)站模板資源下載類網(wǎng)站...
-
電子元件電路板類網(wǎng)站織...
-
儀器分析儀類網(wǎng)站織夢模...
-
裝飾建材公司類網(wǎng)站織夢...
-
營銷型無縫鋼管定制生產(chǎn)...
-
手游APP軟件下載類網(wǎng)站織...
-
財稅記賬工商注冊認(rèn)證類...
-
精工機(jī)械軸承生產(chǎn)廠家類...
由于織夢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;}