dede55前台会员发布的信息在删除时总是不能删除附件,在这里以普通文章图片附件为例跟大家交流一下。
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行找到这两个函数:
/***************************************** 发布文档临时附件信息缓存、发文档前先清空附件信息 发布文档时涉及的附件保存到缓存里,完成后把它与文档关连 ******************************************/ function AddMyAddon($fid, $filename) { $cacheFile = DEDEDATA.'/cache/addon-2'.session_id().'.inc'; if(!file_exists($cacheFile)) { $fp = fopen($cacheFile, 'w'); fwrite($fp, '<'.'?php'."\r\n"); fwrite($fp, "\$myaddons = array();\r\n"); fwrite($fp, "\$maNum = 0;\r\n"); fclose($fp); } //liehuo.net include($cacheFile); $fp = fopen($cacheFile, 'a'); $arrPos = $maNum; $maNum++; fwrite($fp, "\$myaddons[\$maNum] = array('$fid', '$filename');\r\n"); fwrite($fp, "\$maNum = $maNum;\r\n"); 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);下面添加:
$fid = $dsql->GetLastID(); AddMyAddon($fid, $filename); |
第三步:打开member/article_add.php(编辑的话就打开article_edit.php,大同小异),,
大概在16行添加:
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();//添加-->保存后清除缓存。 |