优化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搜索结果进行优化。