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 + -
显示快捷键?