织梦后台其实有个标题重复检测功能,但是依旧可以成功添加入库。我们今天所有做的处理相同重复标题有两个方式,重复标题改为更新内容或重复标题禁止入库。
1、织梦火车头采集器采集相同标题改成更新内容,不再发布相同文档,防止重复。
普通文章实现方法
1、打开 /dede/article_add.php 找到
require_once(DEDEINC.'/image.func.php');
在它上面加入
$arcrow = $dsql->GetOne("SELECT * FROM `archives` WHERE title='$title'"); $aid = $arcrow['id'];if(is_array($arcrow)) { header("HTTP/1.1 307 Moved Permanently"); header("Location:article_edit.php?aid={$aid}&id={$aid}"); exit(); }
如果要保留文档原来的自定义属性或者其他字段的值,可以修改上面的header,例如自定义属性的话这样写 header("Location:article_edit.php?aid={$aid}&id={$aid}&flags[]={$arcrow['flag']}");
完成。
2、判断重复文档,提示并且退出保存文章
打开后台文件夹里面的article_add.php文件然后找到
if(empty($click)) $click = ($cfg_arc_click=='-1' ? mt_rand(50, 200) : $cfg_arc_click);
在下面添加以下代码:
//禁止发布重复标题文章 if($cfg_mb_cktitle=='Y') { $row = $dsql->GetOne("Select * From `dede_archives` where title like '$title' "); if(is_array($row)) { ShowMsg("对不起,请不要发布重复文档!","-1"); exit(); } }
这样就OK
dedecms发表遇到相同的文章标题就会停止。
保存文件,你再添加相同标题的话就会提示文章重复,并且添加文章操作无法把文章加入数据库中了
亲测可用!