为ecshop文章添加关联文章
为 ecshop 文章添加关联文章,这里的关联其实就是相似文章了吧,如果经常看新闻网站的话,会对这个关联很了解了,比如我们看娱乐版块的新闻,某篇娱乐新闻下面必定有其相关联的文章,这样就增加了其文章的粘性,具体的可以看小虎博客的文章,在每一篇文章下面也有其相关文章,说白了就是相似度较高的文章了,好了说了怎么多,下面我们来看一下具体实现的方法吧。
一,首先需要在 mysql 中运行一下 sql 语句:
[code lang="php"]
INSERT INTO `ecs_shop_config` (`id` , `parent_id` , `code` , `type` , `store_range` , `store_dir` , `value` , `sort_order`)
VALUES ( '399', '3', 'article_related', 'select', '0,1', '', '1', '1');
ALTER TABLE `ecs_article` ADD INDEX ( `keywords` );
[/code]
二,新建一个文件 article_related.lbi,将下面的代码保存进去,然后上传到 /themes/default/library/ 目录下.
[code lang="php"]
<?php
$sql_where = " where is_open=1 and article_id != '" .$GLOBALS['article']['article_id'] . "' ";
if ( $GLOBALS['_CFG']['article_related'] == '1' )
{
$sql_where .= " and cat_id = '" . $GLOBALS['article']['cat_id'] . "' ";
}
elseif ( $GLOBALS['_CFG']['article_related'] == '0' )
{
//通过关键字关联
if ($GLOBALS['article']['keywords'])
{
$GLOBALS['article']['keywords'] = str_replace(",", "," , $GLOBALS['article']['keywords']);
$key_list=explode(",", $GLOBALS['article']['keywords']);
$key_id=0;
$sql_or="";
foreach ($key_list as $keyword)
{
$sql_or .= $key_id ? " or " : "";
$sql_or .= " keywords like '%" . trim($keyword) . "%' ";
$key_id++;
}
$sql_or = " ( ". $sql_or ." ) ";
$sql_where .= " and " . $sql_or ;
}
}
$sql="select article_id, cat_id, title, open_type, file_url from " . $GLOBALS['ecs']->table('article') . " $sql_where limit 0,10 ";
//echo $sql;
$res_art_rel=$GLOBALS['db']->query($sql);
while ( $row_art_rel = $GLOBALS['db']->fetchRow($res_art_rel) )
{
$row_art_rel['url']=$row_art_rel['open_type'] != 1 ? build_uri('article', array('aid'=>$row_art_rel['article_id']), $row_art_rel['title']) : trim($row_art_rel['file_url']);
$art_rel_list[]=$row_art_rel;
}
$GLOBALS['smarty']->assign('art_rel_list', $art_rel_list);
?>
<meta http-equiv="Content-Type" content="text/html; charset=gbk">
<style>
.art_rel_tit{clear:both;width:98%;font-size:17px;font-weight:bold;padding:8px 0; margin-top:15px; text-align:left; border-bottom:1px solid #ccc;}
.art_rel_box{width:98%;padding:8px 0;}
.art_rel_box ul{width:100%;}
.art_rel_box ul li{float:left;width:300px;height:25px;}
.art_rel_box ul li a{text-decoration:none;color:#000;}
.art_rel_box ul li a:hover{text-decoration:underline;color:#ff3300;}
</style>
<div class="art_rel_tit">相关文章</div>
<div class="art_rel_box">
<ul>
{foreach from=$art_rel_list item=art_rel}
<li>? <a href="{$art_rel.url}" target="_blank">{$art_rel.title}</a></li>
{/foreach}
</ul>
</div>
<div style="clear:both;"><br></div>
[/code]
注意保存编码的格式要与整站的格式一致,否则会出现乱码的情况。
三,修改模板文件 /themes/default/article.dwt,打开后搜索如下代码:
[code lang="php"]
“ <!-- {if $article.content } -->{$article.content}<!-- {/if} --> ” ,
[/code]
在这段代码的后面添加如下一段代码,位置根据自己的站点进行调整.
[code lang="php"]
<!-- #BeginLibraryItem "/library/article_related.lbi" --><!-- #EndLibraryItem -->
[/code]
四,修改 /languages/zh_cn/admin/shop_config.php 文件,在文件的最后添加上如下代码:
[code lang="php"]
$_LANG['cfg_name']['article_related'] = '相关文章来源';
$_LANG['cfg_desc']['article_related'] = '设定文章详情页 “相关文章” 如何关联';
$_LANG['cfg_range']['article_related'][0] = '通过关键字关联';
$_LANG['cfg_range']['article_related'][1] = '通过文章类别关联';
[/code]
OK,所有操作都已经完成了,在后台进行清理一下缓存,在前台预览一下吧。