⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sys_verifies.php

📁 这是matlab的一个小程序
💻 PHP
字号:
<?php
require_once(dirname(__FILE__)."/config.php");
CheckPurview('sys_Edit');
@set_time_limit(0);
require(DEDEINC.'/dedehttpdown.class.php');

//更新服务器,如果有变动,请到 http://bbs.dedecms.com 查询
$officialUrl = 'http://service.dedecms.com';
$updateHost = 'http://update.dedecms.com/base/';
$updateApp = 'http://update.dedecms.com/app/';

$action = isset($action) ? trim($action) : '';

//当前软件版本锁定文件
$verLockFile = DEDEROOT.'/data/admin/ver.txt';
//当前软件指纹码锁定文件
$verifiesLockFile = DEDEROOT.'/data/admin/verifies.txt';
	
$fp = fopen($verLockFile,'r');
$upTime = trim(fread($fp,64));
fclose($fp);

$updateTime = substr($upTime,0,4).'-'.substr($upTime,4,2).'-'.substr($upTime,6,2);
$verifiesTime = "未同步过指纹码";
if(file_exists($verifiesLockFile))
{
	$fp = fopen($verifiesLockFile,'r');
	$upTime = trim(fread($fp,64));
	fclose($fp);
	$verifiesTime = substr($upTime,0,4).'-'.substr($upTime,4,2).'-'.substr($upTime,6,2);
}

$tmpdir = substr(md5($cfg_cookie_encode),0,16);

if($action == '')
{
	include(DEDEADMIN.'/templets/sys_verifies.htm');
	exit();
}
/*----------------
校验文件
function _verify() { }
----------------*/
else if($action == 'verify')
{
	$dsql->SetQuery("Select * from `#@__verifies` ");
	$dsql->Execute();
	$filelist = array();
	while($row = $dsql->GetArray())
	{
		$turefile = str_replace('../dede', '.', $row['filename']);
		//跳过不存在的文件
		if(!file_exists($turefile)) {
			continue;
		}
		if( filesize($turefile)==0 ) {
			continue;
		}
		$fp = fopen($turefile,'r');
		$ct = fread($fp,filesize($turefile));
		fclose($fp);
		$cthash = md5($ct);
		if($cthash != $row['cthash']) {
			$row['localhash'] = $cthash;
			$row['mtime'] = MyDate('Y-m-d H:i:s', filemtime($turefile));
			$row['turefile'] = $turefile;
			$filelist[] = $row;
		}
	}
	if(!isset($filelist[0]))
	{
		ShowMsg("所有文件都通过效验证,核心文件没有被改动过!","sys_verifies.php");
	}
	else
	{
		include(DEDEADMIN.'/templets/sys_verifies_verify.htm');
	}
	exit();
}
/*--------------------
查看单个本地文件
function _view() { }
----------------------*/
else if ($action == 'view')
{
	require_once(DEDEINC."/oxwindow.class.php");
	
	$filetxt = '';
	if( !eregi('data(.*)common.inc.php',$filename) )
	{
		$fp = fopen($filename,'r');
		$filetxt = fread($fp, filesize($filename));
		fclose($fp);
	}
	
	$filetxt = str_replace('textarea','!textarea',$filetxt);
	
	$wintitle = "文件效验::查看文件";
	$wecome_info = "<a href='sys_verifies.php'><u>文件效验</u></a>::查看文件";
	$win = new OxWindow();
	$win->Init();
	$win->AddTitle("以下为文件 $filename 的内容,请检查是否可疑:");
	$winform = $win->GetWindow("hand","<textarea name='filetxt' style='width:100%;height:450px;word-wrap: break-word;word-break:break-all;'>".$filetxt."</textarea>");
	$win->Display();
	exit();
}
/*-----------------
管理指纹码
function _manage() { }
-------------------*/
else if ($action == 'manage')
{
	$dsql->SetQuery("Select * from `#@__verifies` ");
	$dsql->Execute();
	$filelist = array();
	while($row = $dsql->GetArray())
	{
		$filelist[] = $row;
	}
	include(DEDEADMIN.'/templets/sys_verifies_manage.htm');
	exit();
}
/*-----------------------
下载文件
function _getfiles()
------------------------*/
else if ($action == 'getfiles')
{
	if(!isset($refiles))
	{
		ShowMsg("你没进行任何操作!","sys_verifies.php");
		exit();
	}
	$cacheFiles = DEDEROOT.'/data/modifytmp.inc';
	$fp = fopen($cacheFiles,'w');
	fwrite($fp,'<'.'?php'."\r\n");
	fwrite($fp,'$tmpdir = "'.$tmpdir.'";'."\r\n");
	$dirs = array();
	$i = -1;
	$adminDir = ereg_replace("(.*)[/\\]","",dirname(__FILE__));
	foreach($refiles as $filename)
	{
			$filename = substr($filename,3,strlen($filename)-3);
			if(eregi("^dede/",$filename)) {
				$curdir = GetDirName( eregi_replace("^dede/",$adminDir.'/',$filename) );
			}
			else {
				$curdir = GetDirName($filename);
			}
			if( !isset($dirs[$curdir]) ) {
				$dirs[$curdir] = TestIsFileDir($curdir);
			}
			$i++;
			fwrite($fp,'$files['.$i.'] = "'.$filename.'";'."\r\n");
	}
	fwrite($fp,'$fileConut = '.$i.';'."\r\n");
	fwrite($fp,'?'.'>');
	fclose($fp);
	
	$dirinfos = '';
	if($i > -1)
	{
			$dirinfos = '<tr bgcolor="#ffffff"><td colspan="2">';
			$dirinfos .= "本次升级需要在下面文件夹写入更新文件,请注意文件夹是否有写入权限:<br />\r\n";
			foreach($dirs as $curdir)
			{
				$dirinfos .= $curdir['name']." 状态:".($curdir['writeable'] ? "[√正常]" : "<font color='red'>[×不可写]</font>")."<br />\r\n";
			}
			$dirinfos .= "</td></tr>\r\n";
	}
		
	$doneStr = "<iframe name='stafrm' src='sys_verifies.php?action=down&curfile=0' frameborder='0' id='stafrm' width='100%' height='100%'></iframe>\r\n";
	
	include(DEDEADMIN.'/templets/sys_verifies_getfiles.htm');
	
	exit();
}
/*-----------------------
下载文件
function _down()
------------------------*/
else if($action=='down')
{
	$cacheFiles = DEDEROOT.'/data/modifytmp.inc';
	require_once($cacheFiles);
	
	if($fileConut==-1 || $curfile > $fileConut)
	{
		ShowMsg("已下载所有文件<br /><a href='sys_verifies.php?action=apply'>[直接替换文件]</a> &nbsp; <a href='#'>[我自己手动替换文件]</a>","javascript:;");
		exit();
	}
	
	//检查临时文件保存目录是否可用
	MkTmpDir($tmpdir, $files[$curfile]);
		
	$downfile = $updateHost.$cfg_soft_lang.'/source/'.$files[$curfile];
		
	$dhd = new DedeHttpDown();
	$dhd->OpenUrl($downfile);
	$dhd->SaveToBin(DEDEROOT.'/data/'.$tmpdir.'/'.$files[$curfile]);
	$dhd->Close();
		
	ShowMsg("成功下载文件:{$files[$curfile]}; 继续下载下一个文件。","sys_verifies.php?action=down&curfile=".($curfile+1));
	exit();
}
/*-----------------------
修改效验方式
function _modify()
------------------------*/
else if($action=='modify')
{
	if(!isset($modifys))
	{
		ShowMsg("没选定要修改的文件!","-1");
		exit();
	}
	else
	{
		foreach($modifys as $fname)
		{
			if($method=='local')
			{
				$tureFilename = str_replace('../dede','./',$fname);
				if(file_exists($tureFilename))
				{
					$fp = fopen($tureFilename,'r');
					$ct = fread($fp,filesize($tureFilename));
					fclose($fp);
					$cthash = md5($ct);
					$dsql->ExecuteNoneQuery("update `#@__verifies` set `method`='local',cthash='$cthash' where filename='$fname' ");
				}
			}
			else
			{
				$dsql->ExecuteNoneQuery("update `#@__verifies` set `method`='offical' where filename='$fname' ");
			}
		}
	}
	if($method=='local')
	{
		ShowMsg("成功修改指定文件的验证方式!","sys_verifies.php?action=manage");
	}
	else
	{
		ShowMsg("成功修改指定文件的验证方式!<br /> 由于你修改了文件为远程验证方式,因此需进行更新操作<br /> <a href='sys_verifies.php?action=update'>[更新]</a> &nbsp; <a href='sys_verifies.php?action=manage'>[返回]</a>","javascript:;");
	}
	exit();
}
/*-----------------------
还原文件
function _applyRecover()
------------------------*/
else if ($action == 'apply')
{
	$cacheFiles = DEDEROOT.'/data/modifytmp.inc';
	require_once($cacheFiles);
	$sDir = DEDEROOT."/data/$tmpdir";
	$tDir = DEDEROOT;
		
	$badcp = 0;
	$adminDir = ereg_replace("(.*)[/\\]","",dirname(__FILE__));
		
	if(isset($files) && is_array($files))
	{
			foreach($files as $f)
			{
				if(ereg('^dede',$f)) $tf = ereg_replace('^dede',$adminDir,$f);
				else $tf = $f;
				
				if(file_exists($sDir.'/'.$f))
				{
					//还原文件前先进行文件效验
					$fp = fopen($sDir.'/'.$f,'r');
					$ct = fread($fp,filesize($sDir.'/'.$f));
					fclose($fp);
					$newhash = md5($ct);
					$row = $dsql->GetOne("Select * From `#@__verifies` where filename='../{$f}' ");
					if(is_array($row) && $row['cthash'] != $newhash)
					{
						$badcp++;
					}
					else
					{
						$rs = @copy($sDir.'/'.$f, $tDir.'/'.$tf);
						if($rs) unlink($sDir.'/'.$f);
						else $badcp++;
					}
				}
			}
	}
		
	$badmsg = '!';
	if($badcp > 0)
	{
		$badmsg = ",其 {$badcp} 个文件效验码不正确或复制失败,<br />请从临时目录[../data/{$tmpdir}]中取出这几个文件手动还原。";
	}
		
	ShowMsg("成功完成还原指定文件{$badmsg}","javascript:;");
	exit();
}
/*---------------
在线更新指纹码
function _update()
-----------------*/
else if($action == 'update')
{
	$rmFile = $updateHost.$cfg_soft_lang.'/verifys.txt';
	$dhd = new DedeHttpDown();
	$dhd->OpenUrl($rmFile);
	$ct = $dhd->GetHtml();
	$dhd->Close();
	$cts = split("[\r\n]{1,}",$ct);
	foreach($cts as $ct)
	{
		$ct = trim($ct);
		if(empty($ct)) continue;
		list($nameid,$cthash,$fname) = explode("\t",$ct);
		$row = $dsql->GetOne("Select * From `#@__verifies` where nameid='$nameid' ");
		if(!is_array($row) || ($row['method']=='official' && $row['cthash']!=$cthash ))
		{
			$dsql->ExecuteNoneQuery("Replace Into `#@__verifies`(nameid,cthash,method,filename) values ('$nameid','$cthash','official','$fname'); ");
		}
	}
	$fp = fopen($verifiesLockFile,'w');
	fwrite($fp, MyDate('Ymd',time()));
	fclose($fp);
	ShowMsg("完成效验码更新,是否马上进行效验操作?<br /> <a href='sys_verifies.php?action=verify'>[开始效验]</a> &nbsp; <a href='sys_verifies.php?action=manage'>[管理]</a> &nbsp; <a href='sys_verifies.php'>[返回]</a>","javascript:;");
	exit();
}
/*-----------------
生成指纹码
function _make() { }
-------------------*/
else if ($action == 'make')
{
	$fp = fopen(DEDEROOT.'/data/verifys.txt','w');
	foreach (preg_ls ('../', true, "/.*\.(php|htm|html|js)$/i", 'CVS,data,html,uploads,templets,special') as $onefile)
	{
		$nameid = md5($onefile);
		$cthash = md5(file_get_contents(DEDEADMIN.'/'.$onefile));
		fwrite($fp,"{$nameid}\t{$cthash}\t{$onefile}\r\n");
	}
	fclose($fp);
	ShowMsg("操作成功!","sys_verifies.php");
	exit();
}
//获取所有文件列表
function preg_ls($path=".", $rec=false, $pat="/.*/", $ignoredir='')
{
	while (substr ($path,-1,1) =="/")
	{
		$path=substr ($path,0,-1);
	}
	if (!is_dir ($path) )
	{
		$path=dirname ($path);
	}
	if ($rec!==true)
	{
		$rec=false;
	}
	$d=dir ($path);
	$ret=Array ();
	while (false!== ($e=$d->read () ) )
	{
		if ( ($e==".") || ($e=="..") )
		{
			continue;
		}
		if ($rec && is_dir ($path."/".$e) && ($ignoredir == '' || strpos($ignoredir,$e ) === false))
		{
			$ret=array_merge ($ret,preg_ls($path."/".$e,$rec,$pat,$ignoredir));
			continue;
		}
		if (!preg_match ($pat,$e) )
		{
			continue;
		}
		$ret[]=$path."/".$e;
	}
	return (empty ($ret) && preg_match ($pat,basename($path))) ? Array ($path."/") : $ret;
}
function TestWriteAble($d)
{
	$tfile = '_dedet.txt';
	$fp = @fopen($d.$tfile,'w');
	if(!$fp) {
		return false;
	}
	else {
		fclose($fp);
		$rs = @unlink($d.'/'.$tfile);
		return true;
	}
}

function GetDirName($filename)
{
	$dirname = '../'.ereg_replace("[\\/]{1,}",'/',$filename);
	$dirname = ereg_replace("([^/]*)$",'',$dirname);
	return $dirname;
}

function TestIsFileDir($dirname)
{
	$dirs = array('name'=>'','isdir'=>false,'writeable'=>false);
	$dirs['name'] =  $dirname;
	if(is_dir($dirname))
	{
		$dirs['isdir'] = true;
		$dirs['writeable'] = TestWriteAble($dirname);
	}
	return $dirs;
}

function MkTmpDir($tmpdir,$filename)
{
	$basedir = DEDEROOT.'/data/'.$tmpdir;
	$dirname = trim(ereg_replace("[\\/]{1,}",'/',$filename));
	$dirname = ereg_replace("([^/]*)$","",$dirname);
	if(!is_dir($basedir)) {
		mkdir($basedir,0777);
	}
	if($dirname=='') {
		return true;
	}
	$dirs = explode('/',$dirname);
	$curdir = $basedir;
	foreach($dirs as $d)
	{
		$d = trim($d);
		if(empty($d)) continue;
		$curdir = $curdir.'/'.$d;
		if(!is_dir($curdir)) {
			mkdir($curdir,0777) or die($curdir);
		}
	}
	return true;
}
?>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -