国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

285 řádky
14KB

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