国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

417 lines
16KB

  1. <?php
  2. /**
  3. * @version $Id: index.php 1 13:41 2010年7月26日Z tianya $
  4. * @package DedeCMS.Install
  5. * @copyright Copyright (c) 2007 - 2020, DesDev, Inc.
  6. * @license http://help.dedecms.com/usersguide/license.html
  7. * @link http://www.dedecms.com
  8. */
  9. @set_time_limit(0);
  10. //error_reporting(E_ALL);
  11. error_reporting(E_ALL || ~E_NOTICE);
  12. $verMsg = ' V5.8 UTF8';
  13. $s_lang = 'utf-8';
  14. $dfDbname = 'dedecmsv58utf8';
  15. $errmsg = '';
  16. define('INSTALL_DEMO_NAME', 'dedev57demo.txt');
  17. define('INSLOCKFILE', dirname(__FILE__).'/install_lock.txt');
  18. $moduleCacheFile = dirname(__FILE__).'/modules.tmp.inc';
  19. define('DEDEINC',dirname(__FILE__).'/../include');
  20. define('DEDEDATA',dirname(__FILE__).'/../data');
  21. define('DEDEROOT',preg_replace("#[\\\\\/]install#", '', dirname(__FILE__)));
  22. header("Content-Type: text/html; charset={$s_lang}");
  23. require_once(DEDEROOT.'/install/install.inc.php');
  24. require_once(DEDEINC.'/zip.class.php');
  25. foreach(Array('_GET','_POST','_COOKIE') as $_request)
  26. {
  27. foreach($$_request as $_k => $_v) ${$_k} = RunMagicQuotes($_v);
  28. }
  29. require_once(DEDEINC.'/common.func.php');
  30. if(file_exists(INSLOCKFILE))
  31. {
  32. exit(" 程序已运行安装,如果你确定要重新安装,请先从FTP中删除 install/install_lock.txt!");
  33. }
  34. if(empty($step))
  35. {
  36. $step = 1;
  37. }
  38. /*------------------------
  39. 使用协议书
  40. function _1_Agreement()
  41. ------------------------*/
  42. if($step==1)
  43. {
  44. include('./templates/step-1.html');
  45. exit();
  46. }
  47. /*------------------------
  48. 环境测试
  49. function _2_TestEnv()
  50. ------------------------*/
  51. else if($step==2)
  52. {
  53. $phpv = phpversion();
  54. $sp_os = PHP_OS;
  55. $sp_gd = gdversion();
  56. $sp_server = $_SERVER['SERVER_SOFTWARE'];
  57. $sp_host = (empty($_SERVER['REMOTE_ADDR']) ? $_SERVER['REMOTE_HOST'] : $_SERVER['REMOTE_ADDR']);
  58. $sp_name = $_SERVER['SERVER_NAME'];
  59. $sp_max_execution_time = ini_get('max_execution_time');
  60. $sp_allow_reference = (ini_get('allow_call_time_pass_reference') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
  61. $sp_allow_url_fopen = (ini_get('allow_url_fopen') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
  62. $sp_safe_mode = (ini_get('safe_mode') ? '<font color=red>[×]On</font>' : '<font color=green>[√]Off</font>');
  63. $sp_gd = ($sp_gd>0 ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
  64. $sp_mysql = (function_exists('mysql_connect') ? '<font color=green>[√]On</font>' : '<font color=red>[×]Off</font>');
  65. if($sp_mysql=='<font color=red>[×]Off</font>')
  66. $sp_mysql_err = TRUE;
  67. else
  68. $sp_mysql_err = FALSE;
  69. $sp_testdirs = array(
  70. '/',
  71. '/plus/*',
  72. '/dede/*',
  73. '/data/*',
  74. '/a/*',
  75. '/install',
  76. '/special',
  77. '/uploads/*'
  78. );
  79. include('./templates/step-2.html');
  80. exit();
  81. }
  82. /*------------------------
  83. 设置参数
  84. function _3_WriteSeting()
  85. ------------------------*/
  86. else if($step==3)
  87. {
  88. if(!empty($_SERVER['REQUEST_URI']))
  89. $scriptName = $_SERVER['REQUEST_URI'];
  90. else
  91. $scriptName = $_SERVER['PHP_SELF'];
  92. $basepath = preg_replace("#\/install(.*)$#i", '', $scriptName);
  93. if(!empty($_SERVER['HTTP_HOST']))
  94. $baseurl = 'http://'.$_SERVER['HTTP_HOST'];
  95. else
  96. $baseurl = "http://".$_SERVER['SERVER_NAME'];
  97. $chars='abcdefghigklmnopqrstuvwxwyABCDEFGHIGKLMNOPQRSTUVWXWY0123456789';
  98. $rnd_cookieEncode='';
  99. $length = rand(28,32);
  100. $max = strlen($chars) - 1;
  101. for($i = 0; $i < $length; $i++) {
  102. $rnd_cookieEncode .= $chars[mt_rand(0, $max)];
  103. }
  104. $isdemosign = 0;
  105. if(file_exists(INSTALL_DEMO_NAME) && file_get_contents(INSTALL_DEMO_NAME)) $isdemosign = 1;
  106. $module_local = DEDEDATA.'/module/';
  107. include('./templates/step-3.html');
  108. exit();
  109. }
  110. /*------------------------
  111. 普通安装
  112. function _4_Setup()
  113. ------------------------*/
  114. else if($step==4)
  115. {
  116. if ( $dbtype == 'sqlite' )
  117. {
  118. $db = new SQLite3(DEDEDATA.'/'.$dbname.'.db');
  119. } else {
  120. $dbtype = 'mysql';
  121. $conn = mysql_connect($dbhost,$dbuser,$dbpwd) or die("<script>alert('数据库服务器或登录密码无效,\\n\\n无法连接数据库,请重新设定!');history.go(-1);</script>");
  122. mysql_query("CREATE DATABASE IF NOT EXISTS `".$dbname."`;",$conn);
  123. mysql_select_db($dbname, $conn) or die("<script>alert('选择数据库失败,可能是你没权限,请预先创建一个数据库!');history.go(-1);</script>");
  124. //获得数据库版本信息
  125. $rs = mysql_query("SELECT VERSION();",$conn);
  126. $row = mysql_fetch_array($rs);
  127. $mysqlVersions = explode('.',trim($row[0]));
  128. $mysqlVersion = $mysqlVersions[0].".".$mysqlVersions[1];
  129. mysql_query("SET NAMES '$dblang',character_set_client=binary,sql_mode='';",$conn);
  130. }
  131. $fp = fopen(dirname(__FILE__)."/common.inc.php","r");
  132. $configStr1 = fread($fp,filesize(dirname(__FILE__)."/common.inc.php"));
  133. fclose($fp);
  134. $fp = fopen(dirname(__FILE__)."/config.cache.inc.php","r");
  135. $configStr2 = fread($fp,filesize(dirname(__FILE__)."/config.cache.inc.php"));
  136. fclose($fp);
  137. //common.inc.php
  138. $configStr1 = str_replace("~dbtype~",$dbtype,$configStr1);
  139. $configStr1 = str_replace("~dbhost~",$dbhost,$configStr1);
  140. $configStr1 = str_replace("~dbname~",$dbname,$configStr1);
  141. $configStr1 = str_replace("~dbuser~",$dbuser,$configStr1);
  142. $configStr1 = str_replace("~dbpwd~",$dbpwd,$configStr1);
  143. $configStr1 = str_replace("~dbprefix~",$dbprefix,$configStr1);
  144. $configStr1 = str_replace("~dblang~",$dblang,$configStr1);
  145. @chmod(DEDEDATA,0777);
  146. $fp = fopen(DEDEDATA."/common.inc.php","w") or die("<script>alert('写入配置失败,请检查../data目录是否可写入!');history.go(-1);</script>");
  147. fwrite($fp,$configStr1);
  148. fclose($fp);
  149. //config.cache.inc.php
  150. $cmspath = trim(preg_replace("#\/{1,}#", '/', $cmspath));
  151. if($cmspath!='' && !preg_match("#^\/#", $cmspath)) $cmspath = '/'.$cmspath;
  152. if($cmspath=='') $indexUrl = '/';
  153. else $indexUrl = $cmspath;
  154. $configStr2 = str_replace("~baseurl~",$baseurl,$configStr2);
  155. $configStr2 = str_replace("~basepath~",$cmspath,$configStr2);
  156. $configStr2 = str_replace("~indexurl~",$indexUrl,$configStr2);
  157. $configStr2 = str_replace("~cookieEncode~",$cookieencode,$configStr2);
  158. $configStr2 = str_replace("~webname~",$webname,$configStr2);
  159. $configStr2 = str_replace("~adminmail~",$adminmail,$configStr2);
  160. $fp = fopen(DEDEDATA.'/config.cache.inc.php','w');
  161. fwrite($fp,$configStr2);
  162. fclose($fp);
  163. $fp = fopen(DEDEDATA.'/config.cache.bak.php','w');
  164. fwrite($fp,$configStr2);
  165. fclose($fp);
  166. if($mysqlVersion >= 4.1)
  167. {
  168. $sql4tmp = "ENGINE=MyISAM DEFAULT CHARSET=".$dblang;
  169. }
  170. //创建数据表
  171. $query = '';
  172. $fp = fopen(dirname(__FILE__).'/sql-dftables.txt','r');
  173. while(!feof($fp))
  174. {
  175. $line = rtrim(fgets($fp,1024));
  176. if(preg_match("#;$#", $line))
  177. {
  178. $query .= $line."\n";
  179. $query = str_replace('#@__',$dbprefix,$query);
  180. if ( $dbtype == 'sqlite' )
  181. {
  182. $query = preg_replace('/character set (.*?) /i','',$query);
  183. $query = str_replace('unsigned','',$query);
  184. $query = str_replace('TYPE=MyISAM','',$query);
  185. $query = preg_replace ('/TINYINT\(([\d]+)\)/i','INTEGER',$query);
  186. $query = preg_replace ('/mediumint\(([\d]+)\)/i','INTEGER',$query);
  187. $query = preg_replace ('/smallint\(([\d]+)\)/i','INTEGER',$query);
  188. $query = preg_replace('/int\(([\d]+)\)/i','INTEGER',$query);
  189. $query = preg_replace('/auto_increment/i','PRIMARY KEY AUTOINCREMENT',$query);
  190. $query = preg_replace('/, KEY(.*?)MyISAM;/','',$query);
  191. $query = preg_replace('/, KEY(.*?);/',');',$query);
  192. $query = preg_replace('/, UNIQUE KEY(.*?);/',');',$query);
  193. $query = preg_replace('/set\(([^\)]*?)\)/','varchar',$query);
  194. $query = preg_replace('/enum\(([^\)]*?)\)/','varchar',$query);
  195. if ( preg_match("/PRIMARY KEY AUTOINCREMENT/",$query) )
  196. {
  197. $query = preg_replace('/,([\t\s ]+)PRIMARY KEY \(`([0-9a-zA-Z]+)`\)/i','',$query);
  198. $query = str_replace(', PRIMARY KEY (`id`)','',$query);
  199. }
  200. $db->exec($query);
  201. } else {
  202. if($mysqlVersion < 4.1)
  203. {
  204. $rs = mysql_query($query,$conn);
  205. } else {
  206. if(preg_match('#CREATE#i', $query))
  207. {
  208. $rs = mysql_query(preg_replace("#TYPE=MyISAM#i",$sql4tmp,$query),$conn);
  209. }
  210. else
  211. {
  212. $rs = mysql_query($query,$conn);
  213. }
  214. }
  215. }
  216. $query='';
  217. } else if(!preg_match("#^(\/\/|--)#", $line))
  218. {
  219. $query .= $line;
  220. }
  221. }
  222. fclose($fp);
  223. //导入默认数据
  224. $query = '';
  225. $fp = fopen(dirname(__FILE__).'/sql-dfdata.txt','r');
  226. while(!feof($fp))
  227. {
  228. $line = rtrim(fgets($fp, 1024));
  229. if(preg_match("#;$#", $line))
  230. {
  231. if ( $dbtype == 'sqlite' )
  232. {
  233. $query .= $line;
  234. $query = str_replace('#@__',$dbprefix,$query);
  235. $query = str_replace("\'","\"",$query);
  236. $db->exec($query);
  237. } else {
  238. $query .= $line;
  239. $query = str_replace('#@__',$dbprefix,$query);
  240. if($mysqlVersion < 4.1) $rs = mysql_query($query,$conn);
  241. else $rs = mysql_query(str_replace('#~lang~#',$dblang,$query),$conn);
  242. }
  243. $query='';
  244. } else if(!preg_match("#^(\/\/|--)#", $line))
  245. {
  246. $query .= $line;
  247. }
  248. }
  249. fclose($fp);
  250. //更新配置
  251. $cquery = "Update `{$dbprefix}sysconfig` set value='{$baseurl}' where varname='cfg_basehost';";
  252. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  253. $cquery = "Update `{$dbprefix}sysconfig` set value='{$cmspath}' where varname='cfg_cmspath';";
  254. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  255. $cquery = "Update `{$dbprefix}sysconfig` set value='{$indexUrl}' where varname='cfg_indexurl';";
  256. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  257. $cquery = "Update `{$dbprefix}sysconfig` set value='{$cookieencode}' where varname='cfg_cookie_encode';";
  258. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  259. $cquery = "Update `{$dbprefix}sysconfig` set value='{$webname}' where varname='cfg_webname';";
  260. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  261. $cquery = "Update `{$dbprefix}sysconfig` set value='{$adminmail}' where varname='cfg_adminemail';";
  262. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  263. //增加管理员帐号
  264. $adminquery = "INSERT INTO `{$dbprefix}admin` VALUES (1, 10, '$adminuser', '".substr(md5($adminpwd),5,20)."', 'admin', '', '', 0, '".time()."', '127.0.0.1');";
  265. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  266. //关连前台会员帐号
  267. $adminquery = "INSERT INTO `{$dbprefix}member` (`mid`,`mtype`,`userid`,`pwd`,`uname`,`sex`,`rank`,`money`,`email`,
  268. `scores` ,`matt` ,`face`,`safequestion`,`safeanswer` ,`jointime` ,`joinip` ,`logintime` ,`loginip` )
  269. VALUES ('1','个人','$adminuser','".md5($adminpwd)."','$adminuser','男','100','0','','10000','10','','0','','".time()."','','0',''); ";
  270. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  271. $adminquery = "INSERT INTO `{$dbprefix}member_person` (`mid`,`onlynet`,`sex`,`uname`,`qq`,`msn`,`tel`,`mobile`,`place`,`oldplace`,`birthday`,`star`,
  272. `income` , `education` , `height` , `bodytype` , `blood` , `vocation` , `smoke` , `marital` , `house` ,`drink` , `datingtype` , `language` , `nature` , `lovemsg` , `address`,`uptime`)
  273. VALUES ('1', '1', '男', '{$adminuser}', '', '', '', '', '0', '0','1980-01-01', '1', '0', '0', '160', '0', '0', '0', '0', '0', '0','0', '0', '', '', '', '','0'); ";
  274. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  275. $adminquery = "INSERT INTO `{$dbprefix}member_tj` (`mid`,`article`,`album`,`archives`,`homecount`,`pagecount`,`feedback`,`friend`,`stow`)
  276. VALUES ('1','0','0','0','0','0','0','0','0'); ";
  277. $dbtype == 'sqlite'? $db->exec($adminquery): mysql_query($adminquery,$conn);
  278. $adminquery = "Insert Into `{$dbprefix}member_space`(`mid` ,`pagesize` ,`matt` ,`spacename` ,`spacelogo` ,`spacestyle`, `sign` ,`spacenews`)
  279. Values('1','10','0','{$adminuser}的空间','','person','',''); ";
  280. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  281. //安装体验数据
  282. if($installdemo == 1)
  283. {
  284. if($setupsql = file_get_contents(INSTALL_DEMO_NAME))
  285. {
  286. $setupsql = preg_replace("#ENGINE=MyISAM#i", 'TYPE=MyISAM', $setupsql);
  287. $sql41tmp = 'ENGINE=MyISAM DEFAULT CHARSET='.$cfg_db_language;
  288. if($mysql_version >= 4.1) {
  289. $setupsql = preg_replace("#TYPE=MyISAM#i", $sql41tmp, $setupsql);
  290. }
  291. $setupsql = preg_replace("#_ROOTURL_#i", $rooturl, $setupsql);
  292. $setupsql = preg_replace("#[\r\n]{1,}#", "\n", $setupsql);
  293. $setupsql = preg_replace('/#@__/i',$dbprefix,$setupsql);
  294. $sqls = preg_split("#;[ \t]{0,}\n#", $setupsql);
  295. foreach($sqls as $sql) {
  296. if(trim($sql)!='') mysql_query($sql,$conn);
  297. }
  298. // 更新栏目缓存
  299. UpDateCatCache();
  300. } else {
  301. die("没有体验数据包文件,请检查是否下载.");
  302. }
  303. }
  304. //不安装任何可选模块
  305. if(!isset($modules) || !is_array($modules))
  306. {
  307. //锁定安装程序
  308. $fp = fopen($insLockfile,'w');
  309. fwrite($fp,'ok');
  310. fclose($fp);
  311. include('./templates/step-5.html');
  312. exit();
  313. }
  314. else
  315. {
  316. $module = join(',',$modules);
  317. $fp = fopen($moduleCacheFile,'w');
  318. fwrite($fp,'<'.'?php'."\r\n");
  319. fwrite($fp,'$selModule = "'.$module.'"; '."\r\n");
  320. fwrite($fp,'?'.'>');
  321. //如果不能写入缓存文件,退出模块安装
  322. if(!$fp)
  323. {
  324. //锁定安装程序
  325. $fp = fopen($insLockfile,'w');
  326. fwrite($fp,'ok');
  327. fclose($fp);
  328. $errmsg = "<font color='red'>由于无法写入模块缓存,安装可选模块失败,请登录后在模块管理处安装。</font>";
  329. include('./templates/step-5.html');
  330. exit();
  331. }
  332. fclose($fp);
  333. include('./templates/step-4.html');
  334. exit();
  335. }
  336. exit();
  337. }
  338. /*------------------------
  339. 安装可选模块
  340. function _5_SetupModule()
  341. ------------------------*/
  342. else if($step==5)
  343. {
  344. header("location:module-install.php");
  345. exit();
  346. }
  347. /*------------------------
  348. 检测数据库是否有效
  349. function _10_TestDbPwd()
  350. ------------------------*/
  351. else if($step==10)
  352. {
  353. header("Pragma:no-cache\r\n");
  354. header("Cache-Control:no-cache\r\n");
  355. header("Expires:0\r\n");
  356. $conn = @mysql_connect($dbhost,$dbuser,$dbpwd);
  357. if($conn)
  358. {
  359. if(empty($dbname)){
  360. echo "<font color='green'>信息正确</font>";
  361. }else{
  362. $info = mysql_select_db($dbname,$conn)?"<font color='red'>数据库已经存在,系统将覆盖数据库</font>":"<font color='green'>数据库不存在,系统将自动创建</font>";
  363. echo $info;
  364. }
  365. }
  366. else
  367. {
  368. echo "<font color='red'>数据库连接失败!</font>";
  369. }
  370. @mysql_close($conn);
  371. exit();
  372. }