织梦侠
WWW.2L3.NET

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

文章来自:织梦侠 本文链接:http://www.2l3.net/zqzb/2689.html
当我们发表一篇文章时,一般情况下为了增加用户的停留时间,都会在文章的末尾或者恰当的位置调用跟本文相关的文章,以赢得用户的再次点击,在织梦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";

   }

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

转载请注明文章来自织梦侠[秩名]作者的-织梦cms调用相关文章时likearticle无法排除当前文章的解决方法
联系作者
取消
这个作者很懒什么也没留下!
打赏作者
取消

本文作者无偿奉献,就打赏给我们织梦侠吧!

扫码支付
扫码打赏,建议金额1-10元

打开支付宝扫一扫,即可进行扫码打赏哦

提醒:打赏金额将直接进入对方账号,无法退款,请您谨慎操作。