dedecms删除文章同时也删除附件的修改方法

所属分类: CMS教程 / dedecms 阅读数: 1300
收藏 0 赞 0 分享

我们在做网站发布文章的时候,难免需要一些图片等等让文章更丰富,但是在删除的时候却发现只能删除文章内容,里面曾经上传的图片和附件确实还保留在服务器中,占用着我们有限的空间。

今天织梦模板网就分享一个很实用的功能,删除织梦文章的同时删掉该文章下的图片与附件等文件,有效的节省了后期慢慢排除无用图片和附件的时间还实时节省了一些不必要的存储空间。

实现方法如下:

1.打开/include/extend.func.php文件,在最后加入如下代码

//解析body数据,获得所有图片的绝对地址 
function GetPicsTruePath($body,$litpic) 
{
        $delfiles = array();
        //存储图片地址数据 
        if(!empty($litpic)) 
          {
                $litpicpath = GetTruePath();
                $litpicpath .= $litpic;
                $delfiles[] = $litpicpath;
                //缩略图地址
        }
        preg_match_all("/src=[\"|'|\S|\s]([^ |\/|>]*){0,}(([^>]*)\.(gif|jpg|png))/isU",$body,$tmpdata); 
  $picspath = array_unique($tmpdata[2]);//body中所有图片的地址 
  foreach($picspath as $tmppath) 
  { 
    $path = GetTruePath();//获得绝对路径 
    $picpath = preg_replace("/[a-zA-z]+:\/\/[^ |\/|\s]*/",'',$tmppath);//去掉网址部分 
    $path .=$picpath; 
    $delfiles[] = $path;//保存处理后的数据 
  } 
  return $delfiles; 
} 
//获得文章Body数据  
function GetArcBody($aid)  
{  
global $dsql;  
$query = "SELECT js_addonarticle.body FROM xmzy_addonarticle WHERE xmzy_addonarticle.aid = '$aid'";  
$row = $dsql->GetOne($query);  
if(is_array($row))  
return $row;  
else  
return false;  
} 
//修改于2010.01.28 
//写入日志文件  
function WriteToDelFiles($msg)//删除文章的时候会通过此函数记录日志  
{  
if(empty($msg)) $savemsg="未获得消息";  
else $savemsg = $msg;  
$errorFile = dirname(__FILE__).'/../data/del_body_file.txt';//删除记录文件  
$fp = @fopen($errorFile, 'a');  
@fwrite($fp," {$savemsg}");  
@fclose($fp);  
}

2.打开dede/inc/inc_batchup.php文件,找到:

$arcRow = $dsql->GetOne($arcQuery);

在下边添加:

$arcBodyRow = GetArcBody($aid);

最后找到:

return TRUE;

在这句话上边添加:

//解析Body中的资源,并删除  
$willDelFiles = GetPicsTruePath($arcBodyRow['body'],$arcRow['litpic']);
$nowtime = time();
$executetime = MyDate('Y-m-d H:i:s',$nowtime);
//获得执行时间  
$msg = " 文章标题:$arcRow[title]";
WriteToDelFiles($msg);
if(!empty($willDelFiles))  
{
        foreach($willDelFiles as $file)  
        {
                if(file_exists($file) && !is_dir($file))  
                {
                        if(unlink($file)) $msg = " 位置:$file 结果:删除成功! 时间:$executetime"; else $msg = " 位置:$file 结果:删除失败! 时间:$executetime";
                }
                else $msg = " 位置:$file 结果:文件不存! 时间:$executetime";
                WriteToDelFiles($msg);
        }
        //END foreach
} else  
{
        $msg = " 未在Body中解析到数据 Body原始数据:$arcBodyRow[body] 时间:$executetime";
        WriteToDelFiles($msg);
}

然后保存,这样处理后就实现了删除文章连带当前文章的图片和附件一同删除。

下面是其他网友的补充

首先添加两个函数

/*
根据文档id获取文档的body部分
*/
function getArcBody($arcid)
{
global $dsql;
if(empty($arcid)) return ;
$body = '';
$query = "select arc.*,ch.addtable,ch.fieldset from `dede_arctiny` as arc left join `dede_channeltype` as ch on arc.channel=ch.id where arc.id=$arcid";
$row = $dsql->GetOne($query);
if(empty($row)) return ;
$addtable = $row['addtable'];
$fieldset = $row['fieldset'];
include_once(DEDEINC.'./dedetag.class.php');
$dtp = new DedeTagParse();
$dtp->SetNameSpace('field','<','>');
$dtp->LoadSource($fieldset);
if(is_array($dtp->CTags))
{
foreach($dtp->CTags as $tid=>$tag)
{
if($tag->GetAtt('type')=='htmltext')
{
$body = $tag->GetName();
break;
}
}
}
if(!empty($body))
{
$query = "select $body from `$addtable` where aid=$arcid";
$row = $dsql->GetOne($query);
$body = $row[$body];
return $body;
}
return ;
}
/*
解析文档内容的本地图片图片
*/
function get_img_from_body($body)
{
$result = array();
if(empty($body))
return $result;
preg_match_all('/\ssrc=([\"|\'])([^\1]*?)\.(gif|jpg|jpeg|png)\1/',$body,$res);
if(!empty($res[2]))
{
foreach($res[2] as $k=>$v)
{
$result[] = $v.'.'.$res[3][$k];
}
}
return $result;
}
[/code]
把这段代码贴到include/common.func.php后面,
接着打开后台(假设使用默认的dede作为后台)dede/inc/inc_batchup.php文件,
在第22行添加代码如下:
$body = getArcBody($aid);
接在在第139行,就是在
return true;
上面一行加上下面的代码

复制代码
代码如下:

if($body)
{
$img_arr = get_img_from_body($body);
if(!empty($img_arr))
{
foreach($img_arr as $v)
{
$img_file = GetTruePath().str_replace($GLOBALS['cfg_basehost'],'',$v);
if(file_exists($img_file) && !is_dir($img_file))
@unlink($img_file);
}
}
}

这样就可以实现删除文档的时候删除字段为“htmltext”类型的中的本地图片了。
 

更多精彩内容其他人还在看

Dedecms自定义模型解决会员无法投稿的方法

这篇文章主要为大家介绍了Dedecms自定义模型解决会员无法投稿的方法,通过新建文章模型与栏目实现会员投稿功能,是dedecms二次开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS新建模型字段中【附件样式】的修改方法

这篇文章主要为大家介绍了DedeCMS新建模型字段中【附件样式】的修改方法,是dedecms二次开发中针对字段操作的典型应用,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms的sql标签中传入参数的方法

这篇文章主要为大家介绍了dedecms的sql标签中传入参数的方法,是进行dedecms数据库程序开发中非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

织梦dede后台卡、假死解决方法

用过织梦的网友,特别是dede栏目或是数据非常多的情况下,我们从后台第一次登录的话,不少网友都会发现登录完一般都会出现dede后台卡,或是dede后台卡死,或是非常卡的情况
收藏 0 赞 0 分享

DEDECMS内容页分页过多、过长问题最佳解决方案

最近由于我们网站添加了图片栏目,小编一个图片就分一页这样的话,我们的内容页面的分页就很多,10几个分页一页显示比较难看,所以想到了用这个方法,感觉网友的分享
收藏 0 赞 0 分享

dedecms调用当前栏目的子栏目的两种方法分享

dedecms大家想必不会陌生,算是国内使用较为广泛的一款文章类CMS系统了,使用过程中也许我们需要用到调用当前栏目的子栏目,那么应该如何操作呢,下面我们来分享2种方法
收藏 0 赞 0 分享

dedecms实现列表页缩略图随机调用的方法

这篇文章主要为大家介绍了dedecms实现列表页缩略图随机调用的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms搬家时出现数据库导入失败的解决方法

这篇文章主要为大家介绍了dedecms搬家时出现数据库导入失败的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

dedecms实现将表单订单发送到邮箱实例代码

这篇文章主要为大家介绍了dedecms实现将表单订单发送到邮箱的实现方法,需要的朋友可以参考下
收藏 0 赞 0 分享

DedeCMS实现MySQL修复表的方法

DedeCMS用户碰到数据表出现报错“dede_search_keywords' is marked as crashed and should be repaired”的情况下,就需要对MySQL数据表进行修复。这篇文章主要为大家介绍了DedeCMS实现MySQL修复表的方法,
收藏 0 赞 0 分享
查看更多