概述dede55前台会员发布的信息在
删除时总是不能删除
附件,在这里以普通文章图片附件为例跟大家交流一下。 dede上传的附件信息统统存在uploads表里,而这些附件怎样才能跟其母信息相关联?关键是uploads表里的arcid,也就是母信息的id号。dede在删除母信息时也是通 织梦前台会员发布的信息在删除时总是不能删除附件,在这里以普通文章图片附件为例跟大家交流一下。 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 Clipboard Codes引用的内容:[www.jb51.cc] /***************************************** 发布文档临时附件信息缓存、发文档前先清空附件信息 发布文档时涉及的附件保存到缓存里,完成后把它与文档关连 ******************************************/ 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 Clipboard Codes引用的内容:[www.jb51.cc] $fID = $dsql->GetLastID(); AddMyAddon($fID,$filename); 第三步:打开member/article_add.PHP(编辑的话就打开article_edit.PHP,大同小异), 大概在16行添加: copy to Clipboard Codes引用的内容:[www.jb51.cc] 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了!这样添加信息后缩略图和信息内容中的图片都可以删除了 总结
以上是内存溢出为你收集整理的Dedecms删除文档同时删除图片及附件的方法全部内容,希望文章能够帮你解决Dedecms删除文档同时删除图片及附件的方法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
评论列表(0条)