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 ClipboardLiehuo.Net Codes引用的内容:[]

/***************************************** 

发布文档临时附件信息缓存、发文档前先清空附件信息 

发布文档时涉及的附件保存到缓存里,完成后把它与文档关连 

******************************************/ 

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引用的内容:[]

$fid = $dsql->GetLastID(); 

AddMyAddon($fid, $filename);

第三步:打开member/article_add.php(编辑的话就打开article_edit.php,大同小异),, 

大概在16行添加:

Copy to ClipboardLiehuo.Net Codes引用的内容:[]

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了!这样添加信息后缩略图和信息内容中的图片都可以删除了

给TA打赏
共{{data.count}}人
人已打赏
网站教程

DedeCMS 无法下载远程图片和资源的解决方法

2020-4-12 8:00:00

网站教程

DedeCMS 使用SQL语句批量删除会员

2020-4-14 8:00:00

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索