Dedecms删除文档同时删除图片及附件的方法

织梦前台会员发布的信息在删除时总是不能删除附件,在这里以普通文章图片附件为例跟大家交流一下。
 
  dede上传的附件信息统统存在uploads表里,而这些附件怎样才能跟其母信息相关联?关键是uploads表里的arcid,也就是母信息的id号。dede在删除母信息时也是通过arcid来删除其附件信息。而前台会员上传的附件信息在保存到uploads表里时arcid默认为0,所以在删除母信息时附件肯定删除不了。
 
  例如:添加一条记录,他的id号为1(以arctiny表的id为准 ),信息内容中有5张图片,在保存时这5张图片信息将存为5条uploads记录,并且这5条记录的arcid都为1(dede默认为0)。所以只要我们在上传附件信息时将其母信息的id号同时保存到uploads表里就可以了。
 
  dede后台管理员上传附件时用到两个函数 AddMyAddon()和ClearMyAddon(),AddMyAddon是用来将上传的附件信息存到缓存文件里,在保存母信息时用缓存文件内容替换uploads表里的附件信息记录,等一切都保存完后ClearMyAddon清除缓存。在这里我们移花接木将这两个函数用在前台用户上。
 
  第一步:打开member/memberlogin.class.php,
 
  在第3行添加:session_start();//主要是为了给每个用户建立随机id号
 
  在第84行添加 AddMyAddon函数和ClearMyAddon函数,防止拷贝错误也可以直接打开include/userlogin.class.php文件在79行找到这两个函数:
 
Copy to zuola.net Codes引用的内容:[www.zuola.net]
/***************************************** 
发布文档临时附件信息缓存、发文档前先清空附件信息 
发布文档时涉及的附件保存到缓存里,完成后把它与文档关连 
******************************************/ 
function AddMyAddon($fid, $filename) 
$cacheFile = DEDEDATA.'/cache/addon-2'.session_id().'.inc'; 
if(!file_exists($cacheFile)) 
$fp = fopen($cacheFile, 'w'); 
fwrite($fp, '<'.'?php'." "); 
fwrite($fp, "$myaddons = array(); "); 
fwrite($fp, "$maNum = 0; "); 
fclose($fp); 
} //zuola.net 
include($cacheFile); 
$fp = fopen($cacheFile, 'a'); 
$arrPos = $maNum; 
$maNum++; 
fwrite($fp, "$myaddons[$maNum] = array('$fid', '$filename'); "); 
fwrite($fp, "$maNum = $maNum; "); 
fclose($fp); 
//清理附件,如果关连的文档ID,先把上一批附件传给这个文档ID 
function ClearMyAddon($aid=0, $title='') 
global $dsql; 
$cacheFile = DEDEDATA.'/cache/addon-2'.session_id().'.inc'; 
$_SESSION['bigfile_info'] = array(); 
$_SESSION['file_info'] = array(); 
if(!file_exists($cacheFile)) 
return ; 
//把附件与文档关连 
if(!empty($aid)) 
include($cacheFile); 
foreach($myaddons as $addons) 
if(!empty($title)) { 
$dsql->ExecuteNoneQuery("Update `dede_uploads` set 
 
arcid='$aid',title='$title' where aid='{$addons[0]}'"); 
else { 
$dsql->ExecuteNoneQuery("Update `dede_uploads` set 
 
arcid='$aid' where aid='{$addons[0]}' "); 
@unlink($cacheFile); 
}
第二部:打开member/inc/inc_archives_functions.php 
在144行$dsql->ExecuteNoneQuery($inquery);下面添加:
 
Copy to zuola.net Codes引用的内容:[www.zuola.net]
$fid = $dsql->GetLastID(); 
AddMyAddon($fid, $filename);
第三步:打开member/article_add.php(编辑的话就打开article_edit.php,大同小异),, 
 
大概在16行添加:
 
Copy to zuola.net Codes引用的内容:[www.zuola.net]
ClearMyAddon();//添加-->先清除一下缓存
$cInfos = $dsql->GetOne("Select * From `dede_channeltype` where id='$channelid'; "); 
 
在大概83行 
//生成文档ID 
$arcID = GetIndexKey($arcrank,$typeid,$sortrank,$channelid,$senddate,$mid); 
if(empty($arcID)) 
ShowMsg("无法获得主键,因此无法进行后续操作!","-1"); 
exit(); 
}
 
ClearMyAddon();//添加-->保存后清除缓存。
 
ok了!这样添加信息后缩略图和信息内容中的图片都可以删除了