當我們發表一篇文章時,一般情況下為了增加用戶的停留時間,都會在文章的末尾或者恰當的位置調用跟本文相關的文章,以贏得用戶的再次點擊,在織夢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";    } | 
/*********************************************************************************************/
到此,大功告成,趕緊去試試吧。




















