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

325 lines
15KB

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