www.gusucode.com > Destoon B2B仿淘宝电子商务网站 UTF8 v6.0源码程序 > destoon/install/index.php

    <?php
/*
	[Destoon B2B System] Copyright (c) 2008-2013 Destoon.COM
	This is NOT a freeware, use is subject to license.txt
*/
error_reporting(0);
set_time_limit(0);
set_magic_quotes_runtime(0);
define('IN_DESTOON', true);
define('DT_ADMIN', true);
define('DT_DEBUG', 0);
define('IN_ROOT', str_replace("\\", '/', dirname(__FILE__)));
define('DT_ROOT', substr(IN_ROOT, 0, -8));
define('DT_CACHE', DT_ROOT.'/file/cache');
if($_POST) extract($_POST, EXTR_SKIP);
if($_GET) extract($_GET, EXTR_SKIP);
$submit = isset($_POST['submit']) ? true : false;
$step = isset($_POST['step']) ? $_POST['step'] : 1;
$percent = '0%';
include DT_ROOT.'/config.inc.php';
include DT_ROOT.'/version.inc.php';
define('DT_CHMOD', $CFG['file_mod'] ? $CFG['file_mod'] : '');
header("Content-Type:text/html;charset=".$CFG['charset']);
if(file_exists(DT_CACHE.'/install.lock')) {
	$msg = '安装程序已经被锁定,如果需要解除锁定继续安装<br/>请删除 ./file/cache/install.lock 文件';
	include IN_ROOT.'/msg.tpl.php';
	exit;
}
require DT_ROOT.'/include/global.func.php';
require DT_ROOT.'/include/safe.func.php';
require DT_ROOT.'/include/file.func.php';
require DT_ROOT.'/include/module.func.php';

switch($step) {
	case '1'://协议
		$license = file_get_contents(DT_ROOT.'/license.txt');
		$DT_LICENSE = md5($license);
		if($DT_LICENSE != '5bdef29340ffdbe22c937e38b42292aa' && $DT_LICENSE != '8afcc73ad7d0cd6019899812cc2998a3') {
			$msg = '请检查网站根目录下 license.txt 文件是否存在或被修改<br/>使用Destoon B2B网站管理系统,必须同意license.txt内容,并保留此文件<br/>如果使用FTP上传文件,请使用二进制模式上传 license.txt';
			include IN_ROOT.'/msg.tpl.php';
			exit;
		}
		include IN_ROOT.'/step_'.$step.'.tpl.php';
	break;
	case '2'://环境
		$pass = true;
		$PHP_VERSION = PHP_VERSION;
		if(version_compare($PHP_VERSION, '4.3.0', '<')) {
			$php_pass = $pass = false;
		} else {
			$php_pass = true;
		}
		$PHP_MYSQL = '';
		if(extension_loaded('mysql')) {
			$PHP_MYSQL = '支持';
			$mysql_pass = true;
		} else {
			$PHP_MYSQL = '不支持';
			$mysql_pass = $pass = false;
		}
        $PHP_GD = '';
        if(function_exists('imagejpeg')) $PHP_GD .= 'jpg';
        if(function_exists('imagegif')) $PHP_GD .= ' gif';
        if(function_exists('imagepng')) $PHP_GD .= ' png';
		if($PHP_GD) {
			$gd_pass = true;
		} else {
			$gd_pass = false;
		}
		$PHP_URL = @get_cfg_var("allow_url_fopen");
		$url_pass = $PHP_URL ? true : false;
		$percent = '20%';
		include IN_ROOT.'/step_'.$step.'.tpl.php';
	break;
	case '3'://属性
		$ISWIN = strpos(strtoupper(PHP_OS), 'WIN') === false ? false : true;
		$files = file_get_contents(IN_ROOT.'/chmod.txt');
		$files = explode("\n", $files);
		$files = array_map('trim', $files);
		$FILES = array();
		$pass = true;
		foreach($files as $k=>$v) {
			$FILES[$k]['name'] = $v;
			if(!$ISWIN) dir_chmod(DT_ROOT.'/'.$v, DT_CHMOD);
			if(is_write(DT_ROOT.'/'.str_replace('*', 'index.html', $v))) {
				$FILES[$k]['write'] = true;
				if(strpos($v, 'index.html') !== false) {
					$c = file_get(DT_ROOT.'/'.$v).'<!--WriteTest-->';
					file_put(DT_ROOT.'/'.$v, $c);
					$c = file_get(DT_ROOT.'/'.$v);
					if(strpos($c, 'WriteTest') === false) $FILES[$k]['write'] = $pass = false;
				}
				if($ISWIN && $v == 'config.inc.php') {
					$c = file_get(DT_ROOT.'/'.$v);
					$c = str_replace($CFG['authkey'], 'WriteTest', $c);
					file_put(DT_ROOT.'/'.$v, $c);
					$c = file_get(DT_ROOT.'/'.$v);
					if(strpos($c, 'WriteTest') === false) $FILES[$k]['write'] = $pass = false;
				}
			} else {
				$FILES[$k]['write'] = $pass = false;
			}
		}
		$percent = '40%';
		include IN_ROOT.'/step_'.$step.'.tpl.php';
	break;
	case '4'://数据库
		$DT_URL = get_env('url');
		$DT_URL = substr($DT_URL, 0, strpos($DT_URL, '?') === false ? -17 : -18);
		$percent = '60%';
		include IN_ROOT.'/step_'.$step.'.tpl.php';
	break;
	case '5'://安装进度
		function dexit($msg) {
			echo '<script>alert("'.$msg.'");window.history.back();</script>';
			exit;
		}
		if(!preg_match("/^[a-z0-9]+$/i", $username) || strlen($username) < 4) dexit('请填写正确的超级管理员户名');
		if(strlen($password) < 6) dexit('超级管理员密码最少6位');
		if(strlen($email) < 6 || !preg_match("/^[\w\-\.]+@[\w\-\.]+(\.\w+)+$/", $email)) dexit('请填写正确的超级管理员Email');
		if(!mysql_connect($db_host, $db_user, $db_pass)) dexit('无法连接到数据库服务器,请检查配置');
		$db_name or dexit('请填写数据库名');
		if(!mysql_select_db($db_name)) {
			if(!mysql_query("CREATE DATABASE $db_name")) dexit('指定的数据库不存在\n\n系统尝试创建失败,请通过其他方式建立数据库');
		}

		$config = array();
		$config['db_host'] = $CFG['db_host'] = $db_host;
		$config['db_user'] = $CFG['db_user'] = $db_user;
		$config['db_pass'] = $CFG['db_pass'] = $db_pass;
		$config['db_name'] = $CFG['db_name'] = $db_name;
		$config['tb_pre'] = $CFG['tb_pre'] = $DT_PRE = $tb_pre;
		$config['url'] = $CFG['url'] = $url;
		$config['cache_pre'] = $CFG['cache_pre'] = 'c'.strtolower(random(2)).'_';
		$config['cookie_pre'] = $CFG['cookie_pre'] = 'c'.strtolower(random(2)).'_';
		$config['authkey'] = $CFG['authkey'] = random(16);
		//保存配置文件
		$tmp = file_get_contents(DT_ROOT.'/config.inc.php');
		foreach($config as $k=>$v)	{
			$tmp = preg_replace("/[$]CFG\['$k'\]\s*\=\s*[\"'].*?[\"']/is", "\$CFG['$k'] = '$v'", $tmp);
		}
		file_put(DT_ROOT.'/config.inc.php', $tmp);
		define('DT_PATH', $url);
		define('DT_STATIC', $CFG['static'] ? $CFG['static'] : $CFG['url']);
		define('DT_LANG', $CFG['language']);
		define('DT_KEY', $CFG['authkey']);
		define('DT_CHARSET', $CFG['charset']);
		define('DT_SKIN', DT_PATH.'skin/'.$CFG['skin'].'/');
		define('SKIN_PATH', DT_PATH.'skin/'.$CFG['skin'].'/');
		define('VIP', $CFG['com_vip']);
		define('DT_DOMAIN', $CFG['cookie_domain'] ? substr($CFG['cookie_domain'], 1) : '');
		define('errmsg', 'Invalid Request');

		//创建数据
		require DT_ROOT.'/include/db_mysql.class.php';
		require DT_ROOT.'/include/post.func.php';
		require DT_ROOT.'/include/sql.func.php';
		require DT_ROOT.'/admin/global.func.php';
		$db = new db_mysql();
		$db->connect($db_host, $db_user, $db_pass, $db_name, $CFG['db_expires'], $CFG['db_charset'], $CFG['pconnect']);
		$db->pre = $DT_PRE;
		sql_execute(file_get_contents(IN_ROOT.'/table.sql'));
		sql_execute(file_get_contents(IN_ROOT.'/query.sql'));

		//Setting
		$DT = array();
		for($i = 1; $i <= 22; $i++) {
			$setting = include DT_ROOT.'/file/setting/module-'.$i.'.php';
			if($setting) {
				if($i == 1) $DT = $setting;			unset($setting['moduleid'],$setting['name'],$setting['moduledir'],$setting['ismenu'],$setting['domain'],$setting['linkurl']);
				if($i == 3) {
					foreach($setting as $k=>$v) {
						$setting[$k] = str_replace('http://demo.destoon.com/v'.DT_VERSION.'/', $CFG['url'], $v);
					}
				}
				update_setting($i, $setting);
			}
		}
		
		//替换广告位 单网页路径
		$content = cache_read('ad_14_0.htm', 'htm', 1);
		$content = str_replace('http://demo.destoon.com/v'.DT_VERSION.'/', $CFG['url'], $content);
		cache_write('ad_14_0.htm', $content, 'htm');

		$pay = include DT_ROOT.'/file/setting/pay.php';
		foreach($pay as $k=>$v) {
			update_setting('pay-'.$k, $v);
		}
		$oauth = include DT_ROOT.'/file/setting/oauth.php';
		foreach($oauth as $k=>$v) {
			update_setting('oauth-'.$k, $v);
		}
		$weixin = include DT_ROOT.'/file/setting/weixin.php';
		update_setting('weixin', $weixin);
		$weixin_menu = include DT_ROOT.'/file/setting/weixin-menu.php';
		$weixin_menu[2][0]['key'] = $CFG['url'].'mobile/';
		update_setting('weixin-menu', array('menu' => serialize($weixin_menu)));
		for($i = 1; $i <= 7; $i++) {
			$setting = include DT_ROOT.'/file/setting/group-'.$i.'.php';
			if($setting) {
				unset($setting['groupid'],$setting['groupname'],$setting['vip']);
				update_setting('group-'.$i, $setting);
			}
		}
		$DT_TIME = time();
		$DT_IP = get_env('ip');
		//模块安装时间
		$db->query("UPDATE {$DT_PRE}module SET installtime='$DT_TIME'");

		//设置管理员	
		$paysalt = random(8);
		$payword = dpassword($password, $paysalt);
		$passsalt = random(8);
		$_password = dpassword($password, $passsalt);

		$db->query("UPDATE {$DT_PRE}member SET username='$username',passport='$username',password='$_password',passsalt='$passsalt',payword='$payword',paysalt='$paysalt',email='$email',regip='$DT_IP',regtime='$DT_TIME',loginip='$DT_IP',logintime='$DT_TIME' WHERE userid=1");
		$userurl = $CFG['url'].'index.php?homepage='.$username;
		$db->query("UPDATE {$DT_PRE}company SET username='$username',linkurl='$userurl' WHERE userid=1");

		//替换广告位 单网页路径
		$content = cache_read('ad_14_0.htm', 'htm', 1);
		$content = str_replace('http://demo.destoon.com/v'.DT_VERSION.'/', $CFG['url'], $content);
		cache_write('ad_14_0.htm', $content, 'htm');

		$db->query("UPDATE {$DT_PRE}ad_place SET addtime='$DT_TIME',edittime='$DT_TIME',editor='$username'");
		$db->query("UPDATE {$DT_PRE}ad SET addtime='$DT_TIME',edittime='$DT_TIME',username='$username',editor='$username'");
		$db->query("UPDATE {$DT_PRE}link SET addtime='$DT_TIME',edittime='$DT_TIME',editor='$username'");
		$db->query("UPDATE {$DT_PRE}style SET addtime='$DT_TIME',edittime='$DT_TIME',editor='$username'");
		$db->query("INSERT INTO {$DT_PRE}setting (item,item_key,item_value) VALUES('destoon','backtime','$DT_TIME')");	

		//更新缓存
		require DT_ROOT.'/include/cache.func.php';
		cache_all();
		cache_category(4);
		cache_category(5);
		cache_category(6);
		cache_module();//Again

		//生成首页
		require DT_ROOT.'/include/tag.func.php';
		$CACHE = cache_read('module.php');
		$DT = $CACHE['dt'];
		$MODULE = $CACHE['module'];
		$EXT = cache_read('module-3.php');
		$moduleid = 1;
		$module = 'destoon';
		tohtml('index');

		$msgs = array(
			'保存系统配置.................成功',
			'数据库连接....................成功',
			'创建数据库....................成功',
			'创建数据表....................成功',
			'插入初始数据.................成功',
			'设置管理员....................成功',
			'安装系统模型.................成功',
			'更新系统缓存.................成功',
			'更新模块缓存.................成功',
			'更新模板缓存.................成功',
			'生成网站密钥.................成功',
			'生成网站首页.................成功',
			'锁定安装程序.................就绪',
		);
		$percent = '80%';
		include IN_ROOT.'/step_'.$step.'.tpl.php';
	break;
	case '6'://安装成功
		$percent = '100%';
		include IN_ROOT.'/step_'.$step.'.tpl.php';
		$DT_TIME = time();
		file_put(DT_CACHE.'/install.lock', $DT_TIME);
		$index = file_get(DT_ROOT.'/index.html');
		if(strpos($index, 'install/') !== false) file_del(DT_ROOT.'/index.html');
		file_put(DT_ROOT.'/install/index.php', '<script type="text/javascript">window.location="../?success="+Math.random();</script>');
	break;
	case 'db_test':
		if(!mysql_connect($tdb_host, $tdb_user, $tdb_pass)) exit('<script>alert("无法连接到数据库服务器,请检查配置");</script>');
		if(!mysql_select_db($tdb_name)) {
			if(!mysql_query("CREATE DATABASE $tdb_name")) exit('<script>alert("指定的数据库不存在\n\n系统尝试创建失败,请通过其他方式建立数据库");</script>');
			mysql_select_db($tdb_name);
		}
		$tables = array();
		$query = mysql_list_tables($tdb_name);
		while($r = mysql_fetch_row($query)) {
			$tables[] = $r[0];
		}
		if(is_array($tables) && in_array($ttb_pre."company_setting", $tables)) {
			if($ttb_test) {
				exit('<script>alert("数据库设置正确,连接正常\n\n注意:系统检测到当前数据库已经安装过DESTOON B2B,如果继续安装将会清空现有数据\n\n如果需要保留现有数据,请修改数据表前缀");</script>');
			} else {
				exit('<script>alert("注意:系统检测到当前数据库已经安装过DESTOON B2B,如果继续安装将会清空现有数据\n\n如果需要保留现有数据,请修改数据表前缀");</script>');
			}			
		}
		if($ttb_test) exit('<script>alert("数据库设置正确,连接正常");</script>');
	break;
}
?>