-
Dedecms调用相关文章时排除当前文章的解决方法
- 时间:2025-03-31 12:13:20 来源: 人气:0
在内容管理系统(CMS)中,DedeCMS 是一个非常受欢迎的选择。当我们发布一篇文章时,为了增加用户的停留时间,通常会在文章末尾或适当位置调用与本文相关的文章,以吸引用户再次点击。在 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” 和 “WHERE arc.arcrank>-1 AND $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";
}
通过上述修改,可以确保当前文章不会出现在相似文章的推荐列表中。完成修改后,保存文件并刷新前台页面,即可看到效果。
以上方法简单易行,非常适合需要优化 DedeCMS 相似文章调用功能的用户。希望这篇文章能帮助你更好地理解和使用 DedeCMS 的相关功能!
相关文章
-
在网站建设与维护的过程中,优化代码结构和功能是提升网站性能的重要步骤。本文将介绍如何通过自定义函数实现文章删除时自动清理相关资源的功能,从而提高系统的整洁性和存储效率。以下是具体的操作步骤及代码实现。首先, 在 `/include` 目录下创建一个名为 `extend.func.php` 的文件...2025-03-31
-
在进行图片上传操作时,用户可能会遇到302错误以及带有ERROR提示的图片上传失败问题。这些问题可能由多种原因引发,因此本文将对这些情况进行整理,以帮助大家更有效地定位并解决问题。 第一种情况:图片文件本身损坏。 这种情况会导致系统返回ERROR错误提示,不过发生概率较低。如果怀疑是图片损坏导致的...2025-03-31
-
如果您正在寻找一种高效的方法来使用Dedecms模板搭建网站或论坛,那么本文将为您提供详尽的指导。从模板解压到最终完成配置,每一步都将清晰呈现,帮助您快速掌握整个流程。 第一步:解压Dedecms模板 将下载的Dedecms模板文件解压出来,确保所有文件完整无误。如下图所示: 第二步:获取D...2025-03-31
-
Dedecms Dede 附加表自定义字段与主表文章关联方法
在使用DedeCMS开发装修网站时,设计师和设计作品之间的关联是一个重要的功能需求。通常情况下,文章(作品)的内容部分存储在主表dede_addonarticle中,而自定义字段则存储在附加表dede_archives中。为了实现这一功能,可以采用以下两种方法。 ① 根据发布人调用相关文章; ...2025-03-31