dedecms 删除文章同时删除图片的方法
有时候我们删除文章的时候,文章的图片还是会留存在你的图片文件夹上面,这样很占服务器的内存,程序也会变得很大,所以我们需要删除文章的同时把文章里的图片也对应的删掉,
但织梦本身是不支持的,需要经过小的二次开发才可以,下面织梦58符老师教你们怎么做,经过测试可以用的,
第一步找到
/include/extend.func.php
复制以下的全部代码直接覆盖 到 extend.func.php 文件
第二步 找到
\dede\inc\inc_batchup.php
复制以下的全部代码直接覆盖 到 inc_batchup.php 文件
<?php function DelArc($aid,$type='ON',$onlyfile=false) { global $dsql,$cfg_cookie_encode,$cfg_multi_site,$cfg_medias_dir; global $cuserLogin,$cfg_upload_switch,$cfg_delete,$cfg_basedir; global $admin_catalogs, $cfg_admin_channel; if($cfg_delete == 'N') $type = 'OK'; if(empty($aid)) return ; $aid = ereg_replace("[^0-9]", '', $aid); $arctitle = $arcurl = ''; //查询表信息 $query = "Select ch.maintable,ch.addtable,ch.nid,ch.issystem From `dede_arctiny` arc left join `dede_arctype` tp on tp.id=arc.typeid left join `dede_channeltype` ch on ch.id=arc.channel where arc.id='$aid' "; $row = $dsql->GetOne($query); $nid = $row['nid']; $maintable = (trim($row['maintable'])=='' ? 'dede_archives' : trim($row['maintable'])); $addtable = trim($row['addtable']); $issystem = $row['issystem']; //查询档案信息 if($issystem==-1) { $arcQuery = "Select arc.*,tp.* from `$addtable` arc left join `dede_arctype` tp on arc.typeid=tp.id where arc.aid='$aid' "; } else { $arcQuery = "Select arc.*,tp.*,arc.id as aid from `$maintable` arc left join `dede_arctype` tp on arc.typeid=tp.id where arc.id='$aid' "; } $arcRow = $dsql->GetOne($arcQuery); $arcBodyRow = GetArcBody($aid); //检测权限 if(!TestPurview('a_Del,sys_ArcBatch')) { if(TestPurview('a_AccDel')) { if( !in_array($arcRow['typeid'], $admin_catalogs) && (count($admin_catalogs) != 0 || $cfg_admin_channel != 'all') ) { return false; } } else if(TestPurview('a_MyDel')) { if($arcRow['mid'] != $cuserLogin->getUserID()) { return false; } } else { return false; } } //$issystem==-1 是单表模型,不使用回收站 if($issystem == -1) $type = 'OK'; if(!is_array($arcRow)) return false; /** 删除到回收站 **/ if($cfg_delete == 'Y' && $type == 'ON') { $dsql->ExecuteNoneQuery("Update `$maintable` set arcrank='-2' where id='$aid' "); $dsql->ExecuteNoneQuery("Update `dede_arctiny` set `arcrank` = '-2' where id = '$aid'; "); } else { //删除数据库记录 if(!$onlyfile) { //删除相关附件 if($cfg_upload_switch == 'Y') { $dsql->Execute("me", "SELECT * FROM `dede_uploads` WHERE arcid = '$aid'"); while($row = $dsql->GetArray('me')) { $addfile = $row['url']; $aid = $row['aid']; $dsql->ExecuteNoneQuery("Delete From `dede_uploads` where aid = '$aid' "); $upfile = $cfg_basedir.$addfile; if(@file_exists($upfile)) @unlink($upfile); } } $dsql->ExecuteNoneQuery("Delete From `dede_arctiny` where id='$aid'"); if($addtable != '') { $dsql->ExecuteNoneQuery("Delete From `$addtable` where aid='$aid' "); } if($issystem != -1) { $dsql->ExecuteNoneQuery("Delete From `dede_archives` where id='$aid' "); } $dsql->ExecuteNoneQuery("Delete From `dede_feedback` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_member_stow` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_taglist` where aid='$aid' "); $dsql->ExecuteNoneQuery("Delete From `dede_erradd` where aid='$aid' "); } //删除文本数据 $filenameh = DEDEDATA."/textdata/".(ceil($aid/5000))."/{$aid}-".substr(md5($cfg_cookie_encode),0,16).".txt"; if(@is_file($filenameh)) @unlink($filenameh); } if(empty($arcRow['money'])) $arcRow['money'] = 0; if(empty($arcRow['ismake'])) $arcRow['ismake'] = 1; if(empty($arcRow['arcrank'])) $arcRow['arcrank'] = 0; if(empty($arcRow['filename'])) $arcRow['filename'] = ''; //删除HTML if($arcRow['ismake']==-1 || $arcRow['arcrank']!=0 || $arcRow['typeid']==0 || $arcRow['money']>0) { return true; } //强制转换非多站点模式,以便统一方式获得实际HTML文件 $GLOBALS['cfg_multi_site'] = 'N'; $arcurl = GetFileUrl($arcRow['aid'],$arcRow['typeid'],$arcRow['senddate'],$arcRow['title'],$arcRow['ismake'], $arcRow['arcrank'],$arcRow['namerule'],$arcRow['typedir'],$arcRow['money'],$arcRow['filename']); if(!ereg("\?", $arcurl)) { $htmlfile = GetTruePath().str_replace($GLOBALS['cfg_basehost'],'',$arcurl); if(file_exists($htmlfile) && !is_dir($htmlfile)) { @unlink($htmlfile); $arcurls = explode(".", $htmlfile); $sname = $arcurls[count($arcurls)-1]; $fname = ereg_replace("(\.$sname)$", "", $htmlfile); for($i=2; $i<=100; $i++) { $htmlfile = $fname."_{$i}.".$sname; if( @file_exists($htmlfile) ) @unlink($htmlfile); else break; } } } //解析Body中的资源,并删除 $willDelFiles = GetPicsTruePath($arcBodyRow['body'],$arcRow['litpic']); $nowtime = time(); $executetime = MyDate('Y-m-d H:i:s',$nowtime);//获得执行时间 $msg = "\r\n文章标题:$arcRow[title]"; WriteToDelFiles($msg); if(!empty($willDelFiles)) { foreach($willDelFiles as $file) { if(file_exists($file) && !is_dir($file)) { if(unlink($file)) $msg = "\r\n位置:$file\r\n结果:删除成功!\r\n时间:$executetime"; else $msg = "\r\n位置:$file\r\n结果:删除失败!\r\n时间:$executetime"; } else $msg = "\r\n位置:$file\r\n结果:文件不存!\r\n时间:$executetime"; WriteToDelFiles($msg); }//END foreach } else { $msg = "\r\n未在Body中解析到数据\r\nBody原始数据:$arcBodyRow[body]\r\n时间:$executetime"; WriteToDelFiles($msg); } return true; } //获取真实路径 function GetTruePath($siterefer='', $sitepath='') { $truepath = $GLOBALS['cfg_basedir']; return $truepath; } ?>
到这里就结束了 ,很简单吧, 我们再去试着删除一篇文章 ,你会发现你删除这篇文章以后,这篇文章的缩列图和内容上的图片都同时删除了!
☉首先声明,只要是我们的vip会员所有源码均可以免费下载,不做任何限制
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ(984818011)进行交流。
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ(984818011)进行交流。
相关教程:
- 织梦dede首页列表页获取文章对应的tag标签
- 织梦dede导航栏目顶级和二级判断二级输出不同url
- 织梦dede标签array runphp静态生成乱码BUG解决方法
- 织梦dede如何禁止会员发布文章内容带超链接
- 织梦ajax跨域提交自定义表单和跨域验证码问题
- 织梦CMS MIP文章内容页图片适配百度MIP规范
- 织梦CMS时间格式实现XX秒前、XX分钟前、XX天前
- 织梦DedeCMS更新系统缓存增加清理沉余缓存的功能
- 织梦CMS让channelartlist标签支持currentstyle属性的
- 织梦dede自带编辑器替换百度ueditor编辑器
- 织梦DEDECMS整站动态化或整站静态化设置方法
- 织梦dede 模板路径templets目录都有什么?