织梦dedecms删除文章同时删除附件解决方法

dedecms 在删除文章时,其附件还是保留的,最好的是删除文章同时也删除相应的附件,这样节省空间,删除不必要的垃圾附件,如何解决删除文章同时删除附件呢? 首先添加两个函数 /* 根据文档id获取文档的body部分 */ function getArcBody($arcid) { global $ds
dedecms在删除文章时,其附件还是保留的,最好的是删除文章同时也删除相应的附件,这样节省空间,删除不必要的垃圾附件,如何解决删除文章同时删除附件呢?
 
首先添加两个函数 
 
/*
根据文档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;
}
把这段代码贴到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使用SQL语句批量删除指定ID范围文章 DELETE FROM dede_addonarticle WHERE aid = 1 and aid=2000; DELETE FROM dede_arctiny WHERE id = 1 and id=200
dede模板中通常使用sql批量删除文章的方法dee系统后台中.找到"系统"--"sql命令行工具"输入以下命令DELETE FROM dede_addonarticle WHERE aid = 1 and aid=5000;DELETE FROM dede_arctiny W…