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

织梦CMS 10个月前 (01-16) 119次浏览 已收录 0个评论

我们发表一篇文章时,一般情况下为了增加用户的停留时间,都会在文章的末尾或者恰当的位置调用跟本文相关的文章,以赢得用户的再次点击,在织梦 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 为了排除本文在程序一开头就试图过滤本文(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.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所有丨如需转载请注明文章出处
原文地址:https://www.wangxiaoyou.com/2852.html
喜欢 (0)
[736035566@qq.com]
分享 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址