国内流行的内容管理系统(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.

320 lines
13KB

  1. <?php
  2. /**
  3. * @version $Id: index.php 2021-01-03 tianya $
  4. * @package DedeBIZ.Install
  5. * @copyright Copyright (c) 2021, DedeBIZ.COM
  6. * @license https://www.dedebiz.com/license
  7. * @link https://www.dedebiz.com
  8. */
  9. @set_time_limit(0);
  10. //error_reporting(E_ALL);
  11. error_reporting(E_ALL || ~E_NOTICE);
  12. $verMsg = 'V6';
  13. $dfDbname = 'dedecmsv6';
  14. $errmsg = '';
  15. define('INSLOCKFILE', dirname(__FILE__).'/install_lock.txt');
  16. $moduleCacheFile = dirname(__FILE__).'/modules.tmp.inc';
  17. define('DEDEINC',dirname(__FILE__).'/../include');
  18. define('DEDEDATA',dirname(__FILE__).'/../data');
  19. define('DEDEROOT',preg_replace("#[\\\\\/]install#", '', dirname(__FILE__)));
  20. header("Content-Type: text/html; charset=utf-8");
  21. require_once(DEDEROOT.'/install/install.inc.php');
  22. require_once(DEDEINC.'/zip.class.php');
  23. foreach(Array('_GET','_POST','_COOKIE') as $_request)
  24. {
  25. foreach($$_request as $_k => $_v) ${$_k} = RunMagicQuotes($_v);
  26. }
  27. require_once(DEDEINC.'/common.func.php');
  28. if(file_exists(INSLOCKFILE))
  29. {
  30. exit(" 程序已运行安装,如果你确定要重新安装,请先从FTP中删除 install/install_lock.txt!");
  31. }
  32. if(empty($step))
  33. {
  34. $step = 1;
  35. }
  36. /*------------------------
  37. 使用协议书
  38. function _1_Agreement()
  39. ------------------------*/
  40. if($step==1)
  41. {
  42. $arrMsg = array();
  43. if (!extension_loaded("openssl")) {
  44. $arrMsg[] = "OpenSSL未开启,将无法完成<a href='https://www.dedebiz.com' target='_blank'>DedeBIZ商业支持</a>";
  45. }
  46. if (!extension_loaded("sockets")) {
  47. $arrMsg[] = "Sockets未开启,将无法安装<a href='https://www.dedebiz.com/download#dedebiz' target='_blank'>DedeBIZ商业组件</a>";
  48. }
  49. if (!function_exists('mysqli_connect')) {
  50. $arrMsg[] = "MySQL不支持,将无法使用本系统";
  51. }
  52. if (!extension_loaded("gd")) {
  53. $arrMsg[] = "GD未开启,将无法使用验证码、二维码、图片水印等功能";
  54. }
  55. if(!empty($_SERVER['REQUEST_URI']))
  56. $scriptName = $_SERVER['REQUEST_URI'];
  57. else
  58. $scriptName = $_SERVER['PHP_SELF'];
  59. $basepath = preg_replace("#\/install(.*)$#i", '', $scriptName);
  60. if(!empty($_SERVER['HTTP_HOST']))
  61. $baseurl = 'http://'.$_SERVER['HTTP_HOST'];
  62. else
  63. $baseurl = "http://".$_SERVER['SERVER_NAME'];
  64. $chars='abcdefghigklmnopqrstuvwxwyABCDEFGHIGKLMNOPQRSTUVWXWY0123456789';
  65. $rnd_cookieEncode='';
  66. $length = rand(28,32);
  67. $max = strlen($chars) - 1;
  68. for($i = 0; $i < $length; $i++) {
  69. $rnd_cookieEncode .= $chars[mt_rand(0, $max)];
  70. }
  71. $module_local = DEDEDATA.'/module/';
  72. include('./templates/step-1.html');
  73. exit();
  74. }
  75. /*------------------------
  76. 普通安装
  77. function _2_Setup()
  78. ------------------------*/
  79. else if($step==2)
  80. {
  81. if ( $dbtype == 'sqlite' )
  82. {
  83. $db = new SQLite3(DEDEDATA.'/'.$dbname.'.db');
  84. } else {
  85. $dbtype = 'mysql';
  86. $conn = mysql_connect($dbhost,$dbuser,$dbpwd) or die("<script>alert('数据库服务器或登录密码无效,\\n\\n无法连接数据库,请重新设定!');history.go(-1);</script>");
  87. mysql_query("CREATE DATABASE IF NOT EXISTS `".$dbname."`;",$conn);
  88. mysql_select_db($dbname, $conn) or die("<script>alert('选择数据库失败,可能是你没权限,请预先创建一个数据库!');history.go(-1);</script>");
  89. //获得数据库版本信息
  90. $rs = mysql_query("SELECT VERSION();",$conn);
  91. $row = mysql_fetch_array($rs);
  92. $mysqlVersions = explode('.',trim($row[0]));
  93. $mysqlVersion = $mysqlVersions[0].".".$mysqlVersions[1];
  94. mysql_query("SET NAMES '$dblang',character_set_client=binary,sql_mode='';",$conn);
  95. }
  96. $fp = fopen(dirname(__FILE__)."/common.inc.php","r");
  97. $configStr1 = fread($fp,filesize(dirname(__FILE__)."/common.inc.php"));
  98. fclose($fp);
  99. $fp = fopen(dirname(__FILE__)."/config.cache.inc.php","r");
  100. $configStr2 = fread($fp,filesize(dirname(__FILE__)."/config.cache.inc.php"));
  101. fclose($fp);
  102. //common.inc.php
  103. $configStr1 = str_replace("~dbtype~",$dbtype,$configStr1);
  104. $configStr1 = str_replace("~dbhost~",$dbhost,$configStr1);
  105. $configStr1 = str_replace("~dbname~",$dbname,$configStr1);
  106. $configStr1 = str_replace("~dbuser~",$dbuser,$configStr1);
  107. $configStr1 = str_replace("~dbpwd~",$dbpwd,$configStr1);
  108. $configStr1 = str_replace("~dbprefix~",$dbprefix,$configStr1);
  109. $configStr1 = str_replace("~dblang~",$dblang,$configStr1);
  110. @chmod(DEDEDATA,0777);
  111. $fp = fopen(DEDEDATA."/common.inc.php","w") or die("<script>alert('写入配置失败,请检查../data目录是否可写入!');history.go(-1);</script>");
  112. fwrite($fp,$configStr1);
  113. fclose($fp);
  114. //config.cache.inc.php
  115. $cmspath = trim(preg_replace("#\/{1,}#", '/', $cmspath));
  116. if($cmspath!='' && !preg_match("#^\/#", $cmspath)) $cmspath = '/'.$cmspath;
  117. if($cmspath=='') $indexUrl = '/';
  118. else $indexUrl = $cmspath;
  119. $configStr2 = str_replace("~baseurl~",$baseurl,$configStr2);
  120. $configStr2 = str_replace("~basepath~",$cmspath,$configStr2);
  121. $configStr2 = str_replace("~indexurl~",$indexUrl,$configStr2);
  122. $configStr2 = str_replace("~cookieEncode~",$cookieencode,$configStr2);
  123. $configStr2 = str_replace("~webname~",$webname,$configStr2);
  124. $configStr2 = str_replace("~adminmail~",$adminmail,$configStr2);
  125. $fp = fopen(DEDEDATA.'/config.cache.inc.php','w');
  126. fwrite($fp,$configStr2);
  127. fclose($fp);
  128. $fp = fopen(DEDEDATA.'/config.cache.bak.php','w');
  129. fwrite($fp,$configStr2);
  130. fclose($fp);
  131. if($mysqlVersion >= 4.1)
  132. {
  133. $sql4tmp = "ENGINE=MyISAM DEFAULT CHARSET=".$dblang;
  134. }
  135. //创建数据表
  136. $query = '';
  137. $fp = fopen(dirname(__FILE__).'/sql-dftables.txt','r');
  138. while(!feof($fp))
  139. {
  140. $line = rtrim(fgets($fp,1024));
  141. if(preg_match("#;$#", $line))
  142. {
  143. $query .= $line."\n";
  144. $query = str_replace('#@__',$dbprefix,$query);
  145. if ( $dbtype == 'sqlite' )
  146. {
  147. $query = preg_replace('/character set (.*?) /i','',$query);
  148. $query = str_replace('unsigned','',$query);
  149. $query = str_replace('TYPE=MyISAM','',$query);
  150. $query = preg_replace ('/TINYINT\(([\d]+)\)/i','INTEGER',$query);
  151. $query = preg_replace ('/mediumint\(([\d]+)\)/i','INTEGER',$query);
  152. $query = preg_replace ('/smallint\(([\d]+)\)/i','INTEGER',$query);
  153. $query = preg_replace('/int\(([\d]+)\)/i','INTEGER',$query);
  154. $query = preg_replace('/auto_increment/i','PRIMARY KEY AUTOINCREMENT',$query);
  155. $query = preg_replace('/, KEY(.*?)MyISAM;/','',$query);
  156. $query = preg_replace('/, KEY(.*?);/',');',$query);
  157. $query = preg_replace('/, UNIQUE KEY(.*?);/',');',$query);
  158. $query = preg_replace('/set\(([^\)]*?)\)/','varchar',$query);
  159. $query = preg_replace('/enum\(([^\)]*?)\)/','varchar',$query);
  160. if ( preg_match("/PRIMARY KEY AUTOINCREMENT/",$query) )
  161. {
  162. $query = preg_replace('/,([\t\s ]+)PRIMARY KEY \(`([0-9a-zA-Z]+)`\)/i','',$query);
  163. $query = str_replace(', PRIMARY KEY (`id`)','',$query);
  164. }
  165. $db->exec($query);
  166. } else {
  167. if($mysqlVersion < 4.1)
  168. {
  169. $rs = mysql_query($query,$conn);
  170. } else {
  171. if(preg_match('#CREATE#i', $query))
  172. {
  173. $rs = mysql_query(preg_replace("#TYPE=MyISAM#i",$sql4tmp,$query),$conn);
  174. }
  175. else
  176. {
  177. $rs = mysql_query($query,$conn);
  178. }
  179. }
  180. }
  181. $query='';
  182. } else if(!preg_match("#^(\/\/|--)#", $line))
  183. {
  184. $query .= $line;
  185. }
  186. }
  187. fclose($fp);
  188. //导入默认数据
  189. $query = '';
  190. $fp = fopen(dirname(__FILE__).'/sql-dfdata.txt','r');
  191. while(!feof($fp))
  192. {
  193. $line = rtrim(fgets($fp, 1024));
  194. if(preg_match("#;$#", $line))
  195. {
  196. if ( $dbtype == 'sqlite' )
  197. {
  198. $query .= $line;
  199. $query = str_replace('#@__',$dbprefix,$query);
  200. $query = str_replace("\'","\"",$query);
  201. $db->exec($query);
  202. } else {
  203. $query .= $line;
  204. $query = str_replace('#@__',$dbprefix,$query);
  205. if($mysqlVersion < 4.1) $rs = mysql_query($query,$conn);
  206. else $rs = mysql_query(str_replace('#~lang~#',$dblang,$query),$conn);
  207. }
  208. $query='';
  209. } else if(!preg_match("#^(\/\/|--)#", $line))
  210. {
  211. $query .= $line;
  212. }
  213. }
  214. fclose($fp);
  215. //更新配置
  216. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$baseurl}' WHERE varname='cfg_basehost';";
  217. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  218. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$cmspath}' WHERE varname='cfg_cmspath';";
  219. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  220. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$indexUrl}' WHERE varname='cfg_indexurl';";
  221. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  222. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$cookieencode}' WHERE varname='cfg_cookie_encode';";
  223. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  224. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$webname}' WHERE varname='cfg_webname';";
  225. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  226. $cquery = "UPDATE `{$dbprefix}sysconfig` SET value='{$adminmail}' WHERE varname='cfg_adminemail';";
  227. $dbtype == 'sqlite'? $db->exec($cquery) : mysql_query($cquery,$conn);
  228. //增加管理员帐号
  229. $adminquery = "INSERT INTO `{$dbprefix}admin` VALUES (1, 10, '$adminuser', '".substr(md5($adminpwd),5,20)."', 'admin', '', '', 0, '".time()."', '127.0.0.1');";
  230. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  231. //关连前台会员帐号
  232. $adminquery = "INSERT INTO `{$dbprefix}member` (`mid`,`mtype`,`userid`,`pwd`,`uname`,`sex`,`rank`,`money`,`email`,
  233. `scores` ,`matt` ,`face`,`safequestion`,`safeanswer` ,`jointime` ,`joinip` ,`logintime` ,`loginip` )
  234. VALUES ('1','个人','$adminuser','".md5($adminpwd)."','$adminuser','男','100','0','','10000','10','','0','','".time()."','','0',''); ";
  235. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  236. $adminquery = "INSERT INTO `{$dbprefix}member_person` (`mid`,`onlynet`,`sex`,`uname`,`qq`,`msn`,`tel`,`mobile`,`place`,`oldplace`,`birthday`,`star`,
  237. `income` , `education` , `height` , `bodytype` , `blood` , `vocation` , `smoke` , `marital` , `house` ,`drink` , `datingtype` , `language` , `nature` , `lovemsg` , `address`,`uptime`)
  238. VALUES ('1', '1', '男', '{$adminuser}', '', '', '', '', '0', '0','1980-01-01', '1', '0', '0', '160', '0', '0', '0', '0', '0', '0','0', '0', '', '', '', '','0'); ";
  239. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  240. $adminquery = "INSERT INTO `{$dbprefix}member_tj` (`mid`,`article`,`album`,`archives`,`homecount`,`pagecount`,`feedback`,`friend`,`stow`)
  241. VALUES ('1','0','0','0','0','0','0','0','0'); ";
  242. $dbtype == 'sqlite'? $db->exec($adminquery): mysql_query($adminquery,$conn);
  243. $adminquery = "INSERT INTO `{$dbprefix}member_space`(`mid` ,`pagesize` ,`matt` ,`spacename` ,`spacelogo` ,`spacestyle`, `sign` ,`spacenews`)
  244. VALUES('1','10','0','{$adminuser}的空间','','person','',''); ";
  245. $dbtype == 'sqlite'? $db->exec($adminquery) : mysql_query($adminquery,$conn);
  246. //锁定安装程序
  247. $fp = fopen($insLockfile,'w');
  248. fwrite($fp,'ok');
  249. fclose($fp);
  250. header('Location:dede/index.php');
  251. exit();
  252. }
  253. /*------------------------
  254. 检测数据库是否有效
  255. function _10_TestDbPwd()
  256. ------------------------*/
  257. else if($step==10)
  258. {
  259. header("Pragma:no-cache\r\n");
  260. header("Cache-Control:no-cache\r\n");
  261. header("Expires:0\r\n");
  262. $conn = @mysql_connect($dbhost,$dbuser,$dbpwd);
  263. if($conn)
  264. {
  265. if(empty($dbname)){
  266. echo "<font color='green'>信息正确</font>";
  267. }else{
  268. $info = mysql_select_db($dbname,$conn)?"<font color='red'>数据库已经存在,系统将覆盖数据库</font>":"<font color='green'>数据库不存在,系统将自动创建</font>";
  269. echo $info;
  270. }
  271. }
  272. else
  273. {
  274. echo "<font color='red'>数据库连接失败!</font>";
  275. }
  276. @mysql_close($conn);
  277. exit();
  278. }