加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > CMS系统 > 正文

织梦DedeCMS调用相关文章排除当前文章

发布时间:2020-05-24 23:49:39 所属栏目:CMS系统 来源:互联网
导读:织梦调用相关文章时likearticle无法排除当前文章的解决方法。

下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。脚本之家小编现在分享给大家,也给大家做个参考。

我们发表一篇文章时,一般情况下为了增加用户的停留时间,都会在文章的末尾或者恰当的位置调用跟本文相关的文章,以赢得用户的再次点击,在织梦 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.namerule2,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 为了排除本文在程序一开头就试图过滤本文(ANDarc.id’$aid’ “),但是没成功,那怎么才能成功排除当前文章呢?很简单,我们在这段代码:AND($keyword)$typeid 重新排除一次就可以,两段代码都要加,改完之后如下(注意看绿色加粗代码的地方有什么不同):

if($keyword != '')

{

if(!empty($typeid)) {

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

}

$query = "SELECT arc.*,

tp.namerule2,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,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";

}

到此,大功告成。

以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读