| 
				
				
				
				 | 
			
			 | 
			@@ -0,0 +1,392 @@ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			<?php | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/** | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 * @version        $Id: index.php 1 13:41 2010年7月26日Z tianya $ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 * @package        DedeCMS.Install | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 * @copyright      Copyright (c) 2020, DedeBIZ.COM | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 * @license        https://www.dedebiz.com/license | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 * @link           https://www.dedebiz.com | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			 */ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			@set_time_limit(0); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			//error_reporting(E_ALL); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			error_reporting(E_ALL || ~E_NOTICE); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			$verMsg = 'V6 UTF8'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			$s_lang = 'utf-8'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			$dfDbname = 'dedecmsv6utf8'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			$errmsg = ''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			define('INSLOCKFILE', dirname(__FILE__).'/install_lock.txt'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			$moduleCacheFile = dirname(__FILE__).'/modules.tmp.inc'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			define('DEDEINC',dirname(__FILE__).'/../include'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			define('DEDEDATA',dirname(__FILE__).'/../data'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			define('DEDEROOT',preg_replace("#[\\\\\/]install#", '', dirname(__FILE__))); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			header("Content-Type: text/html; charset={$s_lang}"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			require_once(DEDEROOT.'/install/install.inc.php'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			require_once(DEDEINC.'/zip.class.php'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			foreach(Array('_GET','_POST','_COOKIE') as $_request) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    foreach($$_request as $_k => $_v) ${$_k} = RunMagicQuotes($_v); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			require_once(DEDEINC.'/common.func.php'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			if(file_exists(INSLOCKFILE)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(" 程序已运行安装,如果你确定要重新安装,请先从FTP中删除 install/install_lock.txt!"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			if(empty($step)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $step = 1; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			使用协议书 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _1_Agreement() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			if($step==1) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    include('./templates/step-1.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			环境测试 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _2_TestEnv() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			else if($step==2) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $phpv = phpversion(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_os = PHP_OS; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_gd = gdversion(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_server = $_SERVER['SERVER_SOFTWARE']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_host = (empty($_SERVER['REMOTE_ADDR']) ? $_SERVER['REMOTE_HOST'] : $_SERVER['REMOTE_ADDR']); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_name = $_SERVER['SERVER_NAME']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_max_execution_time = ini_get('max_execution_time'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_openssl = (extension_loaded("openssl") ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_sockets = (extension_loaded("sockets") ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_allow_reference = (ini_get('allow_call_time_pass_reference') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_allow_url_fopen = (ini_get('allow_url_fopen') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_safe_mode = (ini_get('safe_mode') ? '<font color=red>[×]On</font>' : '<font color=green>[√]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_gd = ($sp_gd>0 ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_mysql = (function_exists('mysql_connect') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if($sp_mysql=='<font color=red>[×]Off</font>') | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_mysql_err = TRUE; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_mysql_err = FALSE; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $sp_testdirs = array( | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/plus/*', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/dede/*', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/data/*', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/a/*', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/install', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/special', | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        '/uploads/*' | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    ); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    include('./templates/step-2.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			设置参数 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _3_WriteSeting() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			else if($step==3) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if(!empty($_SERVER['REQUEST_URI'])) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $scriptName = $_SERVER['REQUEST_URI']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $scriptName = $_SERVER['PHP_SELF']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $basepath = preg_replace("#\/install(.*)$#i", '', $scriptName); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if(!empty($_SERVER['HTTP_HOST'])) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $baseurl = 'http://'.$_SERVER['HTTP_HOST']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $baseurl = "http://".$_SERVER['SERVER_NAME']; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $chars='abcdefghigklmnopqrstuvwxwyABCDEFGHIGKLMNOPQRSTUVWXWY0123456789'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $rnd_cookieEncode=''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $length = rand(28,32); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $max = strlen($chars) - 1; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    for($i = 0; $i < $length; $i++) { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $rnd_cookieEncode .= $chars[mt_rand(0, $max)]; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $module_local = DEDEDATA.'/module/'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    include('./templates/step-3.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			普通安装 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _4_Setup() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			else if($step==4) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if ( $dbtype == 'sqlite' ) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $db = new SQLite3(DEDEDATA.'/'.$dbname.'.db'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } else { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $dbtype = 'mysql'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $conn = mysql_connect($dbhost,$dbuser,$dbpwd) or die("<script>alert('数据库服务器或登录密码无效,\\n\\n无法连接数据库,请重新设定!');history.go(-1);</script>"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        mysql_query("CREATE DATABASE IF NOT EXISTS `".$dbname."`;",$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        mysql_select_db($dbname, $conn) or die("<script>alert('选择数据库失败,可能是你没权限,请预先创建一个数据库!');history.go(-1);</script>"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        //获得数据库版本信息 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $rs = mysql_query("SELECT VERSION();",$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $row = mysql_fetch_array($rs); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $mysqlVersions = explode('.',trim($row[0])); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $mysqlVersion = $mysqlVersions[0].".".$mysqlVersions[1]; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        mysql_query("SET NAMES '$dblang',character_set_client=binary,sql_mode='';",$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			     | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(dirname(__FILE__)."/common.inc.php","r"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = fread($fp,filesize(dirname(__FILE__)."/common.inc.php")); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(dirname(__FILE__)."/config.cache.inc.php","r"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = fread($fp,filesize(dirname(__FILE__)."/config.cache.inc.php")); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //common.inc.php | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbtype~",$dbtype,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbhost~",$dbhost,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbname~",$dbname,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbuser~",$dbuser,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbpwd~",$dbpwd,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dbprefix~",$dbprefix,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr1 = str_replace("~dblang~",$dblang,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    @chmod(DEDEDATA,0777); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(DEDEDATA."/common.inc.php","w") or die("<script>alert('写入配置失败,请检查../data目录是否可写入!');history.go(-1);</script>"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fwrite($fp,$configStr1); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //config.cache.inc.php | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cmspath = trim(preg_replace("#\/{1,}#", '/', $cmspath)); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if($cmspath!='' && !preg_match("#^\/#", $cmspath)) $cmspath = '/'.$cmspath; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if($cmspath=='') $indexUrl = '/'; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else $indexUrl = $cmspath; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~baseurl~",$baseurl,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~basepath~",$cmspath,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~indexurl~",$indexUrl,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~cookieEncode~",$cookieencode,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~webname~",$webname,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $configStr2 = str_replace("~adminmail~",$adminmail,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(DEDEDATA.'/config.cache.inc.php','w'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fwrite($fp,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(DEDEDATA.'/config.cache.bak.php','w'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fwrite($fp,$configStr2); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if($mysqlVersion >= 4.1) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $sql4tmp = "ENGINE=MyISAM DEFAULT CHARSET=".$dblang; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //创建数据表 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $query = ''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(dirname(__FILE__).'/sql-dftables.txt','r'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    while(!feof($fp)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $line = rtrim(fgets($fp,1024)); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        if(preg_match("#;$#", $line)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query .= $line."\n"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query = str_replace('#@__',$dbprefix,$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            if ( $dbtype == 'sqlite' ) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/character set (.*?) /i','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = str_replace('unsigned','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = str_replace('TYPE=MyISAM','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace ('/TINYINT\(([\d]+)\)/i','INTEGER',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace ('/mediumint\(([\d]+)\)/i','INTEGER',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace ('/smallint\(([\d]+)\)/i','INTEGER',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/int\(([\d]+)\)/i','INTEGER',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/auto_increment/i','PRIMARY KEY AUTOINCREMENT',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/,  KEY(.*?)MyISAM;/','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/,  KEY(.*?);/',');',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/,  UNIQUE KEY(.*?);/',');',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/set\(([^\)]*?)\)/','varchar',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = preg_replace('/enum\(([^\)]*?)\)/','varchar',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                if ( preg_match("/PRIMARY KEY AUTOINCREMENT/",$query) ) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    $query = preg_replace('/,([\t\s ]+)PRIMARY KEY  \(`([0-9a-zA-Z]+)`\)/i','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    $query = str_replace(',	PRIMARY KEY (`id`)','',$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $db->exec($query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            } else { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                if($mysqlVersion < 4.1) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    $rs = mysql_query($query,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                } else { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    if(preg_match('#CREATE#i', $query)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                        $rs = mysql_query(preg_replace("#TYPE=MyISAM#i",$sql4tmp,$query),$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                        $rs = mysql_query($query,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			     | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query=''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        } else if(!preg_match("#^(\/\/|--)#", $line)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query .= $line; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //导入默认数据 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $query = ''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $fp = fopen(dirname(__FILE__).'/sql-dfdata.txt','r'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    while(!feof($fp)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $line = rtrim(fgets($fp, 1024)); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        if(preg_match("#;$#", $line)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            if ( $dbtype == 'sqlite' ) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query .= $line; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = str_replace('#@__',$dbprefix,$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = str_replace("\'","\"",$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $db->exec($query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            } else { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query .= $line; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                $query = str_replace('#@__',$dbprefix,$query); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                if($mysqlVersion < 4.1) $rs = mysql_query($query,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                else $rs = mysql_query(str_replace('#~lang~#',$dblang,$query),$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			     | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query=''; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        } else if(!preg_match("#^(\/\/|--)#", $line)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $query .= $line; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //更新配置 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$baseurl}' where varname='cfg_basehost';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$cmspath}' where varname='cfg_cmspath';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$indexUrl}' where varname='cfg_indexurl';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$cookieencode}' where varname='cfg_cookie_encode';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$webname}' where varname='cfg_webname';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $cquery = "Update `{$dbprefix}sysconfig` set value='{$adminmail}' where varname='cfg_adminemail';"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($cquery) : mysql_query($cquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //增加管理员帐号 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $adminquery = "INSERT INTO `{$dbprefix}admin` VALUES (1, 10, '$adminuser', '".substr(md5($adminpwd),5,20)."', 'admin', '', '', 0, '".time()."', '127.0.0.1');"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($adminquery) : mysql_query($adminquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //关连前台会员帐号 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $adminquery = "INSERT INTO `{$dbprefix}member` (`mid`,`mtype`,`userid`,`pwd`,`uname`,`sex`,`rank`,`money`,`email`, | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                   `scores` ,`matt` ,`face`,`safequestion`,`safeanswer` ,`jointime` ,`joinip` ,`logintime` ,`loginip` ) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			               VALUES ('1','个人','$adminuser','".md5($adminpwd)."','$adminuser','男','100','0','','10000','10','','0','','".time()."','','0',''); "; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($adminquery) : mysql_query($adminquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $adminquery = "INSERT INTO `{$dbprefix}member_person` (`mid`,`onlynet`,`sex`,`uname`,`qq`,`msn`,`tel`,`mobile`,`place`,`oldplace`,`birthday`,`star`, | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                   `income` , `education` , `height` , `bodytype` , `blood` , `vocation` , `smoke` , `marital` , `house` ,`drink` , `datingtype` , `language` , `nature` , `lovemsg` , `address`,`uptime`) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                VALUES ('1', '1', '男', '{$adminuser}', '', '', '', '', '0', '0','1980-01-01', '1', '0', '0', '160', '0', '0', '0', '0', '0', '0','0', '0', '', '', '', '','0'); "; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($adminquery) : mysql_query($adminquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $adminquery = "INSERT INTO `{$dbprefix}member_tj` (`mid`,`article`,`album`,`archives`,`homecount`,`pagecount`,`feedback`,`friend`,`stow`) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                     VALUES ('1','0','0','0','0','0','0','0','0'); "; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($adminquery): mysql_query($adminquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $adminquery = "Insert Into `{$dbprefix}member_space`(`mid` ,`pagesize` ,`matt` ,`spacename` ,`spacelogo` ,`spacestyle`, `sign` ,`spacenews`) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			                Values('1','10','0','{$adminuser}的空间','','person','',''); "; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $dbtype == 'sqlite'?  $db->exec($adminquery) : mysql_query($adminquery,$conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			
  | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    //不安装任何可选模块 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if(!isset($modules) || !is_array($modules)) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        //锁定安装程序 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $fp = fopen($insLockfile,'w'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fwrite($fp,'ok'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        include('./templates/step-5.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $module = join(',',$modules); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        $fp = fopen($moduleCacheFile,'w'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fwrite($fp,'<'.'?php'."\r\n"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fwrite($fp,'$selModule = "'.$module.'"; '."\r\n"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fwrite($fp,'?'.'>'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        //如果不能写入缓存文件,退出模块安装 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        if(!$fp) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            //锁定安装程序 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $fp = fopen($insLockfile,'w'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            fwrite($fp,'ok'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            $errmsg = "<font color='red'>由于无法写入模块缓存,安装可选模块失败,请登录后在模块管理处安装。</font>"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            include('./templates/step-5.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			            exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        fclose($fp); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        include('./templates/step-4.html'); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			安装可选模块 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _5_SetupModule() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			else if($step==5) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    header("location:module-install.php"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			/*------------------------ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			检测数据库是否有效 | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			function _10_TestDbPwd() | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			------------------------*/ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			else if($step==10) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    header("Pragma:no-cache\r\n"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    header("Cache-Control:no-cache\r\n"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    header("Expires:0\r\n"); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    $conn = @mysql_connect($dbhost,$dbuser,$dbpwd); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    if($conn) | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
					if(empty($dbname)){ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
						echo "<font color='green'>信息正确</font>"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
					}else{ | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
						$info = mysql_select_db($dbname,$conn)?"<font color='red'>数据库已经存在,系统将覆盖数据库</font>":"<font color='green'>数据库不存在,系统将自动创建</font>"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
						echo $info; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
					} | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    else | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    { | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			        echo "<font color='red'>数据库连接失败!</font>"; | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    } | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    @mysql_close($conn); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			    exit(); | 
		
		
	
		
			
			 | 
			 | 
			
			 | 
			} |