index.php.bak 颓废_dede/index.php.bak at master · imvkmark/dede · GitHub

/**

* @version $Id: index.php 1 13:41 2010年7月26日Z tianya $

* @package DedeCMS.Install

* @copyright Copyright (c) 2007 - 2010, DesDev, Inc.

* @license http://help.dedecms.com/usersguide/license.html

* @link http://www.dedecms.com

*/

@set_time_limit(0);

//error_reporting(E_ALL);

error_reporting(E_ALL || ~E_NOTICE);

$verMsg = ' V5.7 UTF8SP1';

$s_lang = 'utf-8';

$dfDbname = 'dedecmsv57utf8sp1';

$errmsg = '';

$install_demo_name = 'dedev57demo.txt';

$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_allow_reference = (ini_get('allow_call_time_pass_reference') ? '[√]On' : '[×]Off');

$sp_allow_url_fopen = (ini_get('allow_url_fopen') ? '[√]On' : '[×]Off');

$sp_safe_mode = (ini_get('safe_mode') ? '[×]On' : '[√]Off');

$sp_gd = ($sp_gd>0 ? '[√]On' : '[×]Off');

$sp_mysql = (function_exists('mysql_connect') ? '[√]On' : '[×]Off');

if($sp_mysql=='[×]Off')

$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'];

$rnd_cookieEncode = chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('A'),ord('Z'))).chr(mt_rand(ord('a'),ord('z'))).mt_rand(1000,9999).chr(mt_rand(ord('A'),ord('Z')));

if(file_get_contents($install_demo_name)) $isdemosign = 1;

$module_local = DEDEDATA.'/module/';

include('./templates/step-3.html');

exit();

}

/*------------------------

普通安装

function _4_Setup()

------------------------*/

else if($step==4)

{

$conn = mysql_connect($dbhost,$dbuser,$dbpwd) or die("");

mysql_query("CREATE DATABASE IF NOT EXISTS `".$dbname."`;",$conn);

mysql_select_db($dbname) or die("");

//获得数据库版本信息

$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("~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("");

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($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))

{

$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';";

mysql_query($cquery,$conn);

$cquery = "Update `{$dbprefix}sysconfig` set value='{$cmspath}' where varname='cfg_cmspath';";

mysql_query($cquery,$conn);

$cquery = "Update `{$dbprefix}sysconfig` set value='{$indexUrl}' where varname='cfg_indexurl';";

mysql_query($cquery,$conn);

$cquery = "Update `{$dbprefix}sysconfig` set value='{$cookieencode}' where varname='cfg_cookie_encode';";

mysql_query($cquery,$conn);

$cquery = "Update `{$dbprefix}sysconfig` set value='{$webname}' where varname='cfg_webname';";

mysql_query($cquery,$conn);

$cquery = "Update `{$dbprefix}sysconfig` set value='{$adminmail}' where varname='cfg_adminemail';";

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');";

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',''); ";

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'); ";

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'); ";

mysql_query($adminquery,$conn);

$adminquery = "Insert Into `{$dbprefix}member_space`(`mid` ,`pagesize` ,`matt` ,`spacename` ,`spacelogo` ,`spacestyle`, `sign` ,`spacenews`)

Values('1','10','0','{$adminuser}的空间','','person','',''); ";

mysql_query($adminquery,$conn);

//安装体验数据

if($installdemo == 1)

{

if($setupsql = file_get_contents($install_demo_name))

{

$setupsql = preg_replace("#ENGINE=MyISAM#i", 'TYPE=MyISAM', $setupsql);

$sql41tmp = 'ENGINE=MyISAM DEFAULT CHARSET='.$cfg_db_language;

if($mysql_version >= 4.1) {

$setupsql = preg_replace("#TYPE=MyISAM#i", $sql41tmp, $setupsql);

}

$setupsql = preg_replace("#_ROOTURL_#i", $rooturl, $setupsql);

$setupsql = preg_replace("#[\r\n]{1,}#", "\n", $setupsql);

$setupsql = preg_replace('/#@__/i',$dbprefix,$setupsql);

$sqls = preg_split("#;[ \t]{0,}\n#", $setupsql);

foreach($sqls as $sql) {

if(trim($sql)!='') mysql_query($sql,$conn);

}

// 更新栏目缓存

UpDateCatCache();

} else {

die("没有体验数据包文件,请检查是否下载.");

}

}

//不安装任何可选模块

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,'

fwrite($fp,'$selModule = "'.$module.'"; '."\r\n");

fwrite($fp,'?'.'>');

//如果不能写入缓存文件,退出模块安装

if(!$fp)

{

//锁定安装程序

$fp = fopen($insLockfile,'w');

fwrite($fp,'ok');

fclose($fp);

$errmsg = "由于无法写入模块缓存,安装可选模块失败,请登录后在模块管理处安装。";

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 "信息正确";

}else{

$info = mysql_select_db($dbname,$conn)?"数据库已经存在,系统将覆盖数据库":"数据库不存在,系统将自动创建";

echo $info;

}

}

else

{

echo "数据库连接失败!";

}

@mysql_close($conn);

exit();

}

else if($step==11)

{

require_once('../data/admin/config_update.php');

$rmurl = $updateHost."dedecms/demodata.{$s_lang}.txt";

$sql_content = file_get_contents($rmurl);

$fp = fopen($install_demo_name,'w');

if(fwrite($fp,$sql_content))

echo '  [√] 存在(您可以选择安装进行体验)';

else

echo '  [×] 远程获取失败';

unset($sql_content);

fclose($fp);

exit();

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值