织梦前台会员发布的信息在删除时总是不能删除附件,在这里以普通文章图片附件为例跟大家交流一下。 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 ClipboardLiehuo.Net Codes引用的内容:[www.dede58.com] /***************************************** 发布文档临时附件信息缓存、发文档前先清空附件信息 发布文档时涉及的附件保存到缓存里,完成后把它与文档关连 ******************************************/ 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); } //liehuo.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 ClipboardLiehuo.Net Codes引用的内容:[www.dede58.com] $fid = $dsql->GetLastID(); AddMyAddon($fid, $filename); 第三步:打开member/article_add.php(编辑的话就打开article_edit.php,大同小异),, 大概在16行添加: Copy to ClipboardLiehuo.Net Codes引用的内容:[www.dede58.com] 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了!这样添加信息后缩略图和信息内容中的图片都可以删除了