织梦dedecms系统删除文章同时删除缩略图和内容大图的修改方法

生命中,好多的事是这样,生活中,好多的情是这样,没有理由,也无需理由,爱就是爱,喜欢就是喜欢,没有结果,也无须结果,心甘情愿,无怨无悔。

有时我们删除文章后,这篇文章内的缩略图和内容图片会留在/uploads/allimg里面,这些图片没有用了,也很占空间,那么我们就需要在删除文章的同时删除缩略图和内容大图,方法如下:

打开dede/inc/inc_batchup.php,找到"//删除数据库的内容",前面加以下代码:

 //删除缩略图
if($arcRow['litpic']!=""){
$dsql->ExecuteNoneQuery("Delete From dede_uploads where url='$arcRow[litpic]'");
$truedir = GetTruePath($arcRow['siterefer'],$arcRow['sitepath']);
$litpicfile = $truedir.$arcRow['litpic'];
@unlink($litpicfile);
}
//删除大图
$arcbodyQuery = "Select * from ".$arcRow['addtable']." where aid='$aid'";
$arcbodyRow = $dsql->GetOne($arcbodyQuery);
$imgsrcarray=GetImageSrc($arcbodyRow['body']);
foreach ($imgsrcarray as $v) {
if((trim($v)!="")&&(!eregi("^http://",$v))){
$dsql->ExecuteNoneQuery("Delete From dede_uploads where url='$v'");
$truedir = GetTruePath($arcRow['siterefer'],$arcRow['sitepath']);
$picfile = $truedir.$v;
@unlink($picfile);
}
}

找到

Select a.ID,a.title,a.typeid,

改成

Select a.ID,a.title,a.typeid,a.litpic,

在页面最后加入函数

//删除文章同时删除大图函数
function GetImageSrc($body){
if( !isset($body)) return;
else{
preg_match_all("/<(img|IMG)(.*)(src|SRC)=[\&;|'|]{0,}([h|\/].*(jpg|JPG|gif|GIF))[\&;|'|\s]{0,}/isU",$body,$out);
return $out[4];
}
}

完成以上修改,就可以了,需要的朋友可以去测试一下。

转自:http://bbs.dedecms.com/read.php?tid=80213

相关阅读:

批量删除织梦(DedeCms)企业会员,垃圾文章的方法

如何删除织梦Dedecms已添加的自定义字段

织梦DedeCMS删除所有栏目或文章后,新建ID不从1开始的解决方法

到此这篇关于织梦dedecms系统删除文章同时删除缩略图和内容大图的修改方法就介绍到这了。世界没有任何变化,只是彼此不再是彼此的牵挂。等不到天黑,烟花不会太完美,回忆烧成灰,还是没有结尾……她静悄悄地来过,他慢慢带走沉默。最后彼此的承诺,消逝在空中楼阁。做错了也不后悔,跌倒了就重新爬起来,要记住:学会坚强,学会自信,永远做生活的强者。更多相关织梦dedecms系统删除文章同时删除缩略图和内容大图的修改方法内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
织梦Linux下安装DedeCMS及安全设置

织梦dede后台缩略图本地上传图片加水印

织梦dede数据还原更新缓存也生成了为什么首页不对

织梦dede文档置顶并显示置顶文字或图标

织梦dede在搜索结果页添加按栏目按模型细分数据