程序员人生 网站导航

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

栏目:DedeCMS时间:2013-12-22 03:55:03

  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'."");
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);下面添加:

$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();//添加-->保存后清除缓存。

ok了!这样添加信息后缩略图和信息内容中的图片都可以删除了

------分隔线----------------------------
------分隔线----------------------------

最新技术推荐