我们在做网站发布文章的时间,不免必要一些图片等等让文章更丰富,但是在删除的时间却发现只能删除文章内容,里面曾经上传的图片和附件确实还保留在服务器中,占用着我们有限的空间。
今天织梦模板网就分享一个很实用的功能,删除织梦文章的同时删掉该文章下的图片与附件等文件,有用的节流了后期慢慢清除无用图片和附件的时间还实时节流了一些不必要的存储空间。
实现方法如下:
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);
复制代码
最后找到:复制代码 在这句话上边添加:- //解析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”类型的中的当地图片了。 |