织梦搜索结果截图
织梦搜索能搜索到内容页关键词实现教程
1、在前台模板搜索框代码内加入一行代码
<input type="hidden" name="channeltype" value="1">
例如
<form name="formsearch" action="{dede:global.cfg_cmspath/}/plus/search.php">
<!-- 必须要指定搜索哪个模型 value="模型id" -->
<input type="hidden" name="channeltype" value="1">
<!-- 必须要指定搜索哪个模型 value="模型id" -->
</form>
2、打开 /include/arc.searchview.class.php 找到 大概在 54 行
var $Sphinx;
在它下面加入
var $addJoin;
继续找到
$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 `dede_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 `dede_arctype` act ON arc.typeid=act.id {$this->addJoin} WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row"; }
这样就实现织梦搜索到文章内容里关键词,也可以修改上面代码实现搜索到任意自定义字段内容关键词。
织梦二次开发QQ群
本站客服QQ号:862782808(点击左边QQ号交流),群号(383578617) 如果您有任何织梦问题,请把问题发到群里,阁主将为您写解决教程!
转载请注明: 织梦模板 » 织梦搜索不能搜索到文章内容里关键词解决方法