王鹏飞seo博客,专注郑州seo,郑州网站优化,百度seo优化,提供免费seo诊断方案。seo外包顾问QQ:931519643,电话15617834052。
Loading
0

织梦调用相关文章时likearticle无法排除当前文章的解决方法

当我们发表一篇文章时,一般情况下为了增加用户的停留时间,都会在文章的末尾或者恰当的位置调用跟本文相关的文章,以赢得用户的再次点击,在织梦dedecms(V5.7版)调用相似文章中,实用的调用代码为{dede:likearticle},这个代码的原理是通过识别文章的标题、类目、关键词等来判断相似度,从而进行推荐,后台调用代码如下/include/taglib/likearticle.lib.php,打开文件找到下面这段代码:

/****************************************************************************************************/

if($keyword != '')

{

if(!empty($typeid)) {

$typeid ="AND arc.typeid IN($typeid) AND arc.id<>'$aid' ";

}

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,

tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath

FROM `dede_archives` arc LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id

where arc.arcrank>-1 AND ($keyword) $typeid $orderquery limit 0, $row";

}

else

{

if(!empty($typeid)) {

$typeid = " arc.typeid IN($typeid) AND arc.id<>'$aid' ";

}

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,

tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath

FROM `dede_archives` arc LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id

WHERE arc.arcrank>-1 AND $typeid $orderquery limit 0, $row";

}

/*********************************************************************************************/

从上面的代码可以看到,织梦dedecms为了排除本文在程序一开头就试图过滤本文(AND arc.id<>'$aid' "),但是没成功,那怎么才能成功排除当前文章呢?很简单,我们在这段代码:AND ($keyword) $typeid 重新排除一次就可以,两段代码都要加,改完之后如下(注意看绿色加粗代码的地方有什么不同):

/****************************************************************************************************/

if($keyword != '')

{

if(!empty($typeid)) {

$typeid ="AND arc.typeid IN($typeid) AND arc.id<>'$aid' ";

}

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,

tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath

FROM `dede_archives` arc LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id

where arc.arcrank>-1 AND ($keyword) $typeid AND arc.id<>'$aid' $orderquery limit 0, $row";

}

else

{

if(!empty($typeid)) {

$typeid = " arc.typeid IN($typeid) AND arc.id<>'$aid' ";

}

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,

tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath

FROM `dede_archives` arc LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id

WHERE arc.arcrank>-1 AND $typeid AND arc.id<>'$aid' $orderquery limit 0, $row";

}

/*********************************************************************************************/

到此,大功告成,赶紧去试试吧。

    本站文章均来自互联网,如有侵权请及时联系郑州seo。并发送侵权证明至邮箱931519643@qq.com,证实后立即删除。
    鞭挞我吧!鞭挞我吧! 鞭挞我吧!鞭挞我吧!

    如果你觉得不错,不如打赏一下!

最后编辑于:2019/5/7作者: 王鹏飞SEO

王鹏飞seo,专注郑州SEO网站优化,分享百度SEO优化知识,提供免费seo优化方案。

暂无评论

发表评论

电子邮件地址不会被公开。 必填项已用*标注

arrow grin ! ? cool roll eek evil razz mrgreen smile oops lol mad twisted wink idea cry shock neutral sad ???

扫一扫,获取免费seo诊断!

扫一扫,获取免费seo诊断!