inc_batchup.php
来自「这是matlab的一个小程序」· PHP 代码 · 共 226 行
PHP
226 行
<?php
function DelArc($aid,$type='ON',$onlyfile=false)
{
global $dsql,$cfg_cookie_encode,$cfg_multi_site,$cfg_medias_dir;
global $cuserLogin,$cfg_upload_switch,$cfg_delete;
if($cfg_delete == 'N')
{
$type = 'OK';
}
$aid = ereg_replace("[^0-9]","",$aid);
if(empty($aid))
{
return ;
}
//读取文档信息
$arctitle = '';
$arcurl = '';
//查询表信息
$query = "Select ch.maintable,ch.addtable,ch.nid,ch.issystem From `#@__arctiny` arc
left join `#@__arctype` tp on tp.id=arc.typeid
left join `#@__channeltype` ch on ch.id=tp.channeltype where arc.id='$aid' ";
$row = $dsql->GetOne($query);
$nid = $row['nid'];
$maintable = (trim($row['maintable'])=='' ? '#@__archives' : trim($row['maintable']));
$addtable = trim($row['addtable']);
$issystem = $row['issystem'];
//查询档案信息
if($issystem==-1)
{
$arcQuery = "Select arc.*,tp.* from `$addtable` arc left join `#@__arctype` tp on arc.typeid=tp.id where arc.aid='$aid' ";
}
else
{
$arcQuery = "Select arc.*,tp.*,arc.id as aid from `$maintable` arc left join `#@__arctype` tp on arc.typeid=tp.id where arc.id='$aid' ";
}
$arcRow = $dsql->GetOne($arcQuery);
//检测权限
if(!TestPurview('a_Del,sys_ArcBatch'))
{
if(TestPurview('a_AccDel'))
{
if(!in_array($arcRow['typeid'],MyCatalogs()))
{
return false;
}
}
else if(TestPurview('a_MyDel'))
{
if($arcRow['mid']!=$cuserLogin->getUserID())
{
return false;
}
}
else
{
return false;
}
}
if(!is_array($arcRow))
{
return false;
}
//$issystem==-1 是单表模型,不使用回收站
if($issystem==-1) $type == 'OK';
/** 删除到回收站 **/
if($cfg_delete == 'Y' && $type == 'ON')
{
$dsql->ExecuteNoneQuery("Update `#@__archives` set arcrank='-2' where id='$aid'");
$dsql->ExecuteNoneQuery("Update `#@__arctiny` set `arcrank` = '-2', `typeid` = '".$arcRow['typeid']."' where id = '$aid'; ");
}
else
{
//删除数据库记录
if(!$onlyfile)
{
//删除相关附件
if($cfg_upload_switch == 'Y' && $addtable != '')
{
if($nid=="image")
{
$addonf = "imgurls";
}
else if($nid=="article")
{
$addonf = "body";
}
else if($nid=="soft")
{
$addonf = "softlinks";
}
else if($nid=="shop")
{
$addonf = "body";
}
else
{
$addonf = '';
}
if($addonf !='' )
{
$row = $dsql->GetOne("SELECT `$addonf` FROM `$addtable` WHERE aid = '$aid'");
if(is_array($row))
{
if($issystem != -1)
{
//查询二返回文章的缩略图;
$licp = $dsql->GetOne("SELECT litpic FROM `#@__archives` WHERE id = '$aid'");
if($licp['litpic'] != "")
{
$litpic = DEDEROOT.$licp['litpic'];
if(file_exists($litpic) && !is_dir($litpic))
{
@unlink($litpic);
}
}
}
$tmpname = '/(\\'.$cfg_medias_dir.'.+?)(\"| )/';
preg_match_all("$tmpname", $row["$addonf"], $delname);
$delname = array_unique($delname['1']);
foreach ($delname as $var)
{
$dsql->ExecuteNoneQuery("Delete From `#@__uploads` where url like '$var' ");
$upname = DEDEROOT.$var;
if(file_exists($upname) && !is_dir($upname))
{
@unlink($upname);
}
}
}
}
}
$dsql->ExecuteNoneQuery("Delete From `#@__arctiny` where id='$aid'");
if($addtable!='')
{
$dsql->ExecuteNoneQuery("Delete From `$addtable` where aid='$aid' ");
}
if($issystem!=-1)
{
$dsql->ExecuteNoneQuery("Delete From `#@__archives` where id='$aid' ");
}
$dsql->ExecuteNoneQuery("Delete From `#@__feedback` where aid='$aid' ");
$dsql->ExecuteNoneQuery("Delete From `#@__member_stow` where aid='$aid' ");
$dsql->ExecuteNoneQuery("Delete From `#@__taglist` where aid='$aid' ");
$dsql->ExecuteNoneQuery("Delete From `#@__erradd` where aid='$aid' ");
}
//删除文本数据
$filenameh = DEDEDATA."/textdata/".(ceil($aid/5000))."/{$aid}-".substr(md5($cfg_cookie_encode),0,16).".txt";
if(is_file($filenameh))
{
@unlink($filenameh);
}
}
if(empty($arcRow['money']))
{
$arcRow['money'] = 0;
}
if(empty($arcRow['ismake']))
{
$arcRow['ismake'] = 1;
}
if(empty($arcRow['arcrank']))
{
$arcRow['arcrank'] = 0;
}
if(empty($arcRow['filename']))
{
$arcRow['filename'] = '';
}
//删除HTML
if($arcRow['ismake']==-1 || $arcRow['arcrank']!=0 || $arcRow['typeid']==0 || $arcRow['money']>0)
{
return true;
}
//强制转换非多站点模式,以便统一方式获得实际HTML文件
$GLOBALS['cfg_multi_site']='N';
$arcurl = GetFileUrl($arcRow['aid'],$arcRow['typeid'],$arcRow['senddate'],$arcRow['title'],$arcRow['ismake'],
$arcRow['arcrank'],$arcRow['namerule'],$arcRow['typedir'],$arcRow['money'],$arcRow['filename']);
if(!ereg("\?",$arcurl))
{
if(eregi('^http:',$arcurl))
{
$arcurl = eregi_replace("^http://([^/]*)/",'/',$arcurl);
}
$htmlfile = GetTruePath().str_replace($GLOBALS['cfg_basehost'],'',$arcurl);
if(file_exists($htmlfile) && !is_dir($htmlfile))
{
@unlink($htmlfile);
$arcurls = explode(".",$htmlfile);
$sname = $arcurls[count($arcurls)-1];
$fname = ereg_replace("(\.$sname)$","",$htmlfile);
for($i=2;$i<=100;$i++)
{
$htmlfile = $fname."_{$i}.".$sname;
if(file_exists($htmlfile) && !is_dir($htmlfile))
{
@unlink($htmlfile);
}
else
{
break;
}
}
}
}
return true;
}
//获取真实路径
function GetTruePath($siterefer='',$sitepath='')
{
$truepath = $GLOBALS["cfg_basedir"];
return $truepath;
}
?>
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?