织梦前台搜索标题和文档内容关键词都能搜到文章实现教程
Posted 北方的刀郎
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了织梦前台搜索标题和文档内容关键词都能搜到文章实现教程相关的知识,希望对你有一定的参考价值。
织梦前台搜索标题和文档内容关键词都能搜到文章实现教程
实现教程
在前台模板搜索框代码内加入一行代码
<input type="hidden" name="channeltype" value="1">
例如
-
<form name="formsearch" action="{dede:global.cfg_cmspath/}/plus/search.php">
-
<!-- 必须要指定搜索哪个模型 value="模型id" 文章是1,产品是6要对应的上-->
-
<input type="hidden" name="channeltype" value="1">
-
<!-- 必须要指定搜索哪个模型 value="模型id" -->
-
</form>
打开 /include/arc.searchview.class.php 找到 大概在 54 行
var $Sphinx;
继续找到
$hascode = md5($cquery);
在它上面加入
if($this->ChannelType > 0)
{
$this->AddSql = join(' AND ',$ksqls) . " AND ( CONCAT(addf.body,arc.title) LIKE '%{$this->Keyword}%') ";
$row = $this->dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id={$this->ChannelType}");
$addtable = trim($row['addtable']);
$this->addJoin = " LEFT JOIN `{$addtable}` addf ON arc.id=addf.aid ";
$cquery = "SELECT arc.*,addf.* FROM `{$this->AddTable}` arc {$this->addJoin} WHERE ".$this->AddSql;
}
注意:上面中的 addf.body 就是文章内容字段,如果你要搜索其他字段,改成你的自定义字段名称
继续找到
WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";
在它下面加入
if($this->ChannelType > 0)
{
$query = "SELECT arc.*,act.typedir,act.typename,act.isdefault,act.defaultname,act.namerule,
act.namerule2,act.ispart,act.moresite,act.siteurl,act.sitepath,addf.*
FROM `{$this->AddTable}` arc LEFT JOIN `#@__arctype` act ON arc.typeid=act.id {$this->addJoin}
WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";
}
完成
以上是关于织梦前台搜索标题和文档内容关键词都能搜到文章实现教程的主要内容,如果未能解决你的问题,请参考以下文章