📄 upgrade10.php
字号:
<?php
error_reporting(E_ERROR | E_WARNING | E_PARSE);
@set_magic_quotes_runtime(0);
@set_time_limit(0);
define('DISCUZ_ROOT', getcwd().'/');
define('IN_DISCUZ', TRUE);
$lang = array(
'error_message' => '错误信息',
'message_return' => '返回',
'old_step' => '上一步',
'new_step' => '下一步',
'uc_appname' => '论坛',
'uc_appreg' => '注册',
'uc_appreg_succeed' => '到 UCenter 成功,',
'uc_continue' => '点击这里继续',
'uc_setup' => '<font color="red">如果没有安装过,点击这里安装 UCenter</font>',
'uc_title_ucenter' => '请填写 UCenter 的相关信息',
'uc_url' => 'UCenter 的 URL',
'uc_ip' => 'UCenter 的 IP',
'uc_admin' => 'UCenter 的管理员帐号',
'uc_adminpw' => 'UCenter 的管理员密码',
'uc_title_app' => '相关信息',
'uc_app_name' => '的名称',
'uc_app_url' => '的 URL',
'uc_app_ip' => '的 IP',
'uc_app_ip_comment' => '当主机 DNS 有问题时需要设置,默认请保留为空',
'uc_connent_invalid1' => '连接服务器',
'uc_connent_invalid2' => ' 失败,请返回检查。',
'error_message' => '提示信息',
'error_return' => '返回',
'tagtemplates_subject' => '标题',
'tagtemplates_uid' => '用户 ID',
'tagtemplates_username' => '发帖者',
'tagtemplates_dateline' => '日期',
'tagtemplates_url' => '主题地址',
);
$msglang = array(
'redirect_msg' => '浏览器会自动跳转页面,无需人工干预。除非当您的浏览器长时间没有自动跳转时,请点击这里',
'uc_url_empty' => '您没有填写 UCenter 的 URL,请返回填写。',
'uc_url_invalid' => 'UCenter 的 URL 格式不合法,正常的格式为: http://www.domain.com ,请返回检查。',
'uc_ip_invalid' => '<font color="red">无法连接 UCenter 所在的 Web 服务器,请填写 UCenter 服务器的IP,如果 UCenter 与论坛在同一台服务器,可以尝试填写:127.0.0.1。</font>',
'uc_admin_invalid' => '<font color="red">登录 UCenter 的管理员帐号密码错误。</font>',
'uc_data_invalid' => 'UCenter 获取数据失败,请返回检查 UCenter URL、管理员帐号、密码。 ',
);
require DISCUZ_ROOT.'./include/db_mysql.class.php';
@include DISCUZ_ROOT.'./config.inc.php';
$version['old'] = 'Discuz! 6.0.0 正式版';
$version['new'] = 'Discuz! 6.1.0 正式版';
instheader();
if(!$dbhost || !$dbname || !$dbuser) {
instmsg('论坛数据库的主机,数据库名,用户名为空。');
}
$db = new dbstuff();
$db->connect($dbhost, $dbuser, $dbpw, $dbname, $pconnect, true, $dbcharset);
function get_charset($tablename) {
global $db;
$tablestruct = $db->fetch_first("show create table $tablename");
preg_match("/CHARSET=(\w+)/", $tablestruct['Create Table'], $m);
return $m[1];
}
if($db->version() > '4.1.0') {
$tablethreadcharset = get_charset($tablepre.'threads');
$dbcharset = strtolower($dbcharset);
$tablethreadcharset = strtolower($tablethreadcharset);
if($dbcharset && $dbcharset != $tablethreadcharset) {
instmsg("您的配置文件 (./config.inc.php) 中的字符集 ($dbcharset) 与表的字符集 ($tablethreadcharset) 不匹配。");
}
}
$upgrade1 = <<<EOT
DROP TABLE IF EXISTS cdb_request;
CREATE TABLE cdb_request (
variable varchar(32) NOT NULL DEFAULT '',
value mediumtext NOT NULL,
type tinyint(1) NOT NULL,
PRIMARY KEY (variable),
KEY type (type)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_reportlog;
CREATE TABLE cdb_reportlog (
id int(10) unsigned NOT NULL auto_increment,
fid smallint(6) unsigned NOT NULL,
pid int(10) unsigned NOT NULL,
uid mediumint(8) unsigned NOT NULL,
username char(15) NOT NULL,
status tinyint(1) unsigned NOT NULL default '1',
type tinyint(1) NOT NULL,
reason char(40) NOT NULL,
dateline int(10) unsigned NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY pid (pid,uid),
KEY dateline (fid,dateline)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_warnings;
CREATE TABLE cdb_warnings (
wid smallint(6) unsigned NOT NULL auto_increment,
pid int(10) unsigned NOT NULL,
operatorid mediumint(8) unsigned NOT NULL,
operator char(15) NOT NULL,
authorid mediumint(8) unsigned NOT NULL,
author char(15) NOT NULL,
dateline int(10) unsigned NOT NULL,
reason char(40) NOT NULL,
PRIMARY KEY (wid),
UNIQUE KEY pid (pid)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_medallog;
CREATE TABLE cdb_medallog (
id mediumint(8) unsigned NOT NULL auto_increment,
uid mediumint(8) unsigned NOT NULL default '0',
medalid smallint(6) unsigned NOT NULL default '0',
type tinyint(1) NOT NULL default '0',
dateline int(10) unsigned NOT NULL default '0',
expiration int(10) unsigned NOT NULL default '0',
status tinyint(1) NOT NULL default '0',
PRIMARY KEY (id),
KEY type (type),
KEY status (status,expiration),
KEY uid (uid,medalid,type)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_admincustom;
CREATE TABLE cdb_admincustom (
id smallint(6) unsigned NOT NULL auto_increment,
title varchar(50) NOT NULL,
url varchar(255) NOT NULL,
sort tinyint(1) NOT NULL default '0',
displayorder tinyint(3) NOT NULL,
clicks smallint(6) unsigned NOT NULL default '1',
uid mediumint(8) unsigned NOT NULL,
dateline int(10) unsigned NOT NULL,
PRIMARY KEY (id),
KEY uid (uid),
KEY displayorder (displayorder)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_virtualforums;
CREATE TABLE cdb_virtualforums (
fid smallint(6) unsigned NOT NULL auto_increment,
cid mediumint(8) unsigned NOT NULL,
fup smallint(6) unsigned NOT NULL,
`type` enum('group','forum') NOT NULL default 'forum',
`name` varchar(255) NOT NULL,
description text NOT NULL,
logo varchar(255) NOT NULL,
`status` tinyint(1) NOT NULL,
threads mediumint(8) unsigned NOT NULL DEFAULT '0',
posts mediumint(8) unsigned NOT NULL DEFAULT '0',
lastpost varchar(255) NOT NULL DEFAULT '',
displayorder tinyint(3) NOT NULL,
PRIMARY KEY (fid),
KEY forum (`status`,`type`,displayorder),
KEY fup (fup)
) TYPE=MyISAM;
DROP TABLE IF EXISTS cdb_advcaches;
CREATE TABLE cdb_advcaches (
advid mediumint(8) unsigned NOT NULL auto_increment,
`type` varchar(50) NOT NULL default '0',
target smallint(6) NOT NULL,
`code` mediumtext NOT NULL,
PRIMARY KEY (advid)
) ENGINE=MyISAM;
DROP TABLE IF EXISTS cdb_adminsessions;
CREATE TABLE cdb_adminsessions (
uid mediumint(8) unsigned NOT NULL DEFAULT '0',
adminid smallint(6) unsigned NOT NULL DEFAULT '0',
panel tinyint(1) NOT NULL DEFAULT '0',
ip varchar(15) NOT NULL DEFAULT '',
dateline int(10) unsigned NOT NULL DEFAULT '0',
errorcount tinyint(1) NOT NULL DEFAULT '0',
`storage` mediumtext NOT NULL,
PRIMARY KEY (uid,panel)
) TYPE=MyISAM;
EOT;
$upgradetable = array(
array('forums', 'ADD', 'allowtag', "TINYINT(1) NOT NULL DEFAULT '1'"),
array('forums', 'ADD', 'modworks', "TINYINT(1) UNSIGNED NOT NULL"),
array('forums', 'DROP', 'allowpaytoauthor', ""),
array('medals', 'ADD', 'type', "TINYINT( 1 ) NOT NULL DEFAULT '0'"),
array('medals', 'ADD', 'displayorder', "TINYINT( 3 ) NOT NULL DEFAULT '0'"),
array('medals', 'INDEX', '', "ADD INDEX displayorder (displayorder)"),
array('medals', 'ADD', 'description', "VARCHAR( 255 ) NOT NULL"),
array('medals', 'ADD', 'expiration', "SMALLINT( 6 ) unsigned NOT NULL DEFAULT '0'"),
array('medals', 'ADD', 'permission', "MEDIUMTEXT NOT NULL"),
array('memberfields', 'CHANGE', 'medals', "medals TEXT NOT NULL"),
array('usergroups', 'ADD', 'exempt', "TINYINT(1) unsigned NOT NULL"),
array('members', 'ADD', 'customaddfeed', "TINYINT( 1 ) NOT NULL DEFAULT '0'"),
array('campaigns', 'ADD', 'url', "CHAR(255) NOT NULL"),
array('campaigns', 'ADD', 'autoupdate', "TINYINT(1) unsigned NOT NULL"),
array('campaigns', 'ADD', 'lastupdated', "INT(10) unsigned NOT NULL"),
array('usergroups', 'DROP', 'maxpmnum', ""),
array('access', 'ADD', 'adminuser', "MEDIUMINT(8) unsigned NOT NULL DEFAULT '0'"),
array('access', 'ADD', 'dateline', "INT(10) unsigned NOT NULL DEFAULT '0'"),
array('access', 'INDEX', '', "ADD INDEX listorder (fid,dateline)"),
array('videos', 'ADD', 'displayorder', "TINYINT(3) NOT NULL DEFAULT '0' AFTER dateline"),
array('videos', 'INDEX', '', "ADD INDEX displayorder (displayorder)"),
);
$upgrade3 = <<<EOT
REPLACE INTO cdb_settings (variable, value) VALUES ('attachexpire', '');
REPLACE INTO cdb_settings (variable, value) VALUES ('admode', 1);
REPLACE INTO cdb_settings (variable, value) VALUES ('infosidestatus', '');
REPLACE INTO cdb_settings (variable, value) VALUES ('seclevel', 1);
REPLACE INTO cdb_settings (variable, value) VALUES ('warninglimit', '3');
REPLACE INTO cdb_settings (variable, value) VALUES ('warningexpiration', '30');
REPLACE INTO cdb_settings (variable, value) VALUES ('thumbquality', '100');
REPLACE INTO cdb_settings (variable, value) VALUES ('relatedtag', '');
REPLACE INTO cdb_settings (variable, value) VALUES ('outextcredits', '');
REPLACE INTO cdb_settings (variable, value) VALUES ('uc', 'a:1:{s:7:"addfeed";i:1;}');
DELETE FROM cdb_settings WHERE variable='allowcsscache';
DELETE FROM cdb_settings WHERE variable='seccodeanimator';
DELETE FROM cdb_settings WHERE variable='maxavatarsize';
DELETE FROM cdb_settings WHERE variable='maxavatarpixel';
DELETE FROM cdb_settings WHERE variable like 'passport_%';
DELETE FROM cdb_settings WHERE variable like 'supe_%';
DELETE FROM cdb_crons WHERE filename='supe_daily.inc.php';
INSERT INTO cdb_crons VALUES (NULL,'1','system','每日勋章更新','medals_daily.inc.php','0','1170600452','-1','-1','0','0');
UPDATE cdb_usergroups SET exempt=255 WHERE radminid = 1;
UPDATE cdb_usergroups SET exempt=255 WHERE radminid = 2;
UPDATE cdb_usergroups SET exempt=224 WHERE radminid = 3;
EOT;
$uchidden = '<input type="hidden" name="ucdbhost" value="'.$_POST['ucdbhost'].'">';
$uchidden .= '<input type="hidden" name="ucdbname" value="'.$_POST['ucdbname'].'">';
$uchidden .= '<input type="hidden" name="ucdbuser" value="'.$_POST['ucdbuser'].'">';
$uchidden .= '<input type="hidden" name="ucdbpw" value="'.$_POST['ucdbpw'].'">';
$uchidden .= '<input type="hidden" name="uctablepre" value="'.$_POST['uctablepre'].'">';
$uchidden .= '<input type="hidden" name="ucdbcharset" value="'.$_POST['ucdbcharset'].'">';
$uchidden .= '<input type="hidden" name="ucapi" value="'.$_POST['ucapi'].'">';
$uchidden .= '<input type="hidden" name="ucip" value="'.$_POST['ucip'].'">';
$uchidden .= '<input type="hidden" name="uccharset" value="'.$_POST['uccharset'].'">';
$uchidden .= '<input type="hidden" name="appid" value="'.$_POST['appid'].'">';
$uchidden .= '<input type="hidden" name="appauthkey" value="'.$_POST['appauthkey'].'">';
$step = getgpc('step');
$step = empty($step) ? 1 : $step;
if(!isset($cookiepre)) {
instmsg('config_nonexistence');
} elseif(!ini_get('short_open_tag')) {
instmsg('short_open_tag_invalid');
}
if($step == 1) {
$msg = '';
if(file_exists(DISCUZ_ROOT.'forumdata/upgrademaxuid.log')) {
$msg = '<b><font color="red">升级程序检测到您执行过本程序,请点击一下链接,选择操作:</font></b><br />
<li><a href="'.$PHP_SELF.'?step=uc&restart=yes"><font size="2">我已恢复旧版数据, 请点击这里重新升级</font></a><br />
<li><a href="'.$PHP_SELF.'?step=uc"><font size="2">继续以前的升级</font></a><br />';
} else {
$msg = '<a href="'.$PHP_SELF.'?step=uc"><font size="2"><b>>> 如果您已确认完成上面的步骤,请点这里升级</b></font></a>';
}
echo <<<EOT
<h4>本升级程序只能从 $version[old] 升级到 $version[new]<br /></h4>
升级之前<b>务必备份数据库资料</b>,否则升级失败无法恢复<br /><br />
正确的升级方法为:
<ol>
<li>请确认已经安装了 UCenter
<li>关闭原有论坛,上传 $version[new] 的全部文件和目录,覆盖服务器上的 $version[old]
<li>上传升级程序到论坛目录中,重新配置好 config.inc.php
<li>运行本程序,直到出现升级完成的提示
<li>如果中途失败,请使用Discuz!工具箱(./utilities/tools.php)里面的数据恢复工具恢复备份,去除错误后重新运行本程序
</ol>
$msg
EOT;
instfooter();
} elseif($step == 'uc') {
if(!empty($_GET['restart'])) {
@unlink(DISCUZ_ROOT.'forumdata/upgrademaxuid.log');
@unlink(DISCUZ_ROOT.'forumdata/upgrade.log');
@unlink(DISCUZ_ROOT.'forumdata/repeatuser.log');
}
define('APP_NAME', $_POST['appname'] ? $_POST['appname'] : $lang['uc_appname']);
define('APP_TYPE', 'DISCUZ');
define('APP_CHARSET', $charset);
define('APP_DBCHARSET', $dbcharset ? $dbcharset : (in_array(strtolower($charset), array('gbk', 'big5', 'utf-8')) ? str_replace('-', '', $charset) : 'gbk'));
define('APP_URL', strtolower(substr($_SERVER['SERVER_PROTOCOL'], 0, strpos($_SERVER['SERVER_PROTOCOL'], '/'))).'://'.$_SERVER['HTTP_HOST'].substr($_SERVER['PHP_SELF'], 0, strrpos($_SERVER['PHP_SELF'], '/')));
define('APP_NEXTSTEP', $_SERVER['PHP_SELF'].'?step=2');
$ucip = $ucapi = $uciperror = '';
if(!empty($_POST['ucsubmit'])) {
$ucapi = getgpc('ucapi', 'P');
$ucip = getgpc('ucip', 'P');
$ucfounderpw = getgpc('ucfounderpw', 'P');
$appip = getgpc('appip', 'P');
$hidden .= var_to_hidden('ucapi', $ucapi);
$hidden .= var_to_hidden('ucfounderpw', $ucfounderpw);
$ucapi = preg_replace("/\/$/", '', trim($ucapi));
if(empty($ucapi)) {
instmsg('uc_url_empty');
} elseif(!preg_match("/^(http:\/\/)/i", $ucapi)) {
instmsg('uc_url_invalid');
}
if(!$ucip) {
parse_url($ucapi);
$matches = parse_url($ucapi);
$host = $matches['host'];
$port = !empty($matches['port']) ? $matches['port'] : 80;
if(!preg_match("/^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$/", $host)) {
$ucip = gethostbyname($host);
$ucip = $ucip == $host ? '' : $ucip;
} else {
$ucip = $host;
}
}
$connect_error = false;
$pw_error = false;
if(!$ucip) {
$uciperror = $msglang['uc_ip_invalid'];
} else {
$app_tagtemplates = 'apptagtemplates[template]='.urlencode('<a href="{url}" target="_blank">{subject}</a>').'&'.
'apptagtemplates[fields][subject]='.urlencode($lang['tagtemplates_subject']).'&'.
'apptagtemplates[fields][uid]='.urlencode($lang['tagtemplates_uid']).'&'.
'apptagtemplates[fields][username]='.urlencode($lang['tagtemplates_username']).'&'.
'apptagtemplates[fields][dateline]='.urlencode($lang['tagtemplates_dateline']).'&'.
'apptagtemplates[fields][url]='.urlencode($lang['tagtemplates_url']);
$postdata = "m=app&a=add&ucfounderpw=".urlencode($ucfounderpw)."&apptype=".urlencode(APP_TYPE)."&appname=".urlencode(APP_NAME)."&appurl=".urlencode(APP_URL)."&appip=&appcharset=".APP_CHARSET.'&appdbcharset='.APP_DBCHARSET.'&'.$app_tagtemplates;
$s = dfopen($ucapi.'/index.php', 0, $postdata, '', 1, $ucip);
if(empty($s)) {
$connect_error = true;
$uciperror = $msglang['uc_ip_invalid'];
//instmsg($lang['uc_connent_invalid1'].$ucapi.' ('.$ucip.')'.$lang['uc_connent_invalid2']);
} elseif($s == '-1') {
$pw_error = $msglang['uc_admin_invalid'];
} else {
list($appauthkey, $appid, $ucdbhost, $ucdbname, $ucdbuser, $ucdbpw, $ucdbcharset, $uctablepre, $uccharset) = explode('|', $s);
if(empty($appauthkey) || empty($appid)) {
$connect_error = true;
$uciperror = $msglang['uc_ip_invalid'];
//instmsg('uc_data_invalid');
} else {
$apphidden = var_to_hidden('ucdbhost', $ucdbhost);
$apphidden .= var_to_hidden('ucdbname', $ucdbname);
$apphidden .= var_to_hidden('ucdbuser', $ucdbuser);
$apphidden .= var_to_hidden('ucdbpw', $ucdbpw);
$apphidden .= var_to_hidden('uctablepre', $uctablepre);
$apphidden .= var_to_hidden('ucdbcharset', $ucdbcharset);
$apphidden .= var_to_hidden('ucapi', $ucapi);
$apphidden .= var_to_hidden('ucip', $ucip);
$apphidden .= var_to_hidden('uccharset', $uccharset);
$apphidden .= var_to_hidden('appid', $appid);
$apphidden .= var_to_hidden('appauthkey', $appauthkey);
instmsg($lang['uc_appreg'].APP_NAME.$lang['uc_appreg_succeed'].'<form action="'.APP_NEXTSTEP.'" method="post">'.$apphidden.'</form><br /><a href="javascript:document.forms[0].submit();">'.$lang['uc_continue'].'</a><script type="text/javascript">setTimeout("document.forms[0].submit()", 1000);</script>');
}
}
}
}
?>
<form method="post" action="<?=$_SERVER['PHP_SELF']?>?step=uc">
<table width="80%" cellspacing="1" bgcolor="#000000" border="0" align="center">
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -