Index.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2021 勾股工作室
  4. * @license https://opensource.org/licenses/Apache-2.0
  5. * @link https://www.gougucms.com
  6. */
  7. declare (strict_types = 1);
  8. namespace app\install\controller;
  9. use app\install\validate\InstallCheck;
  10. use mysqli;
  11. use think\exception\ValidateException;
  12. use think\facade\View;
  13. class Index
  14. {
  15. public function __construct()
  16. {
  17. // 检测是否安装过
  18. if (is_installed()) {
  19. echo '你已经安装过勾股cms系统!如需重新安装,请删除“config/install.lock”文件';
  20. die();
  21. }
  22. if(!extension_loaded('fileinfo')){
  23. echo '你还未安装(开启)PHP的【fileinfo】扩展,该扩展主要用于文件上传,请先安装(开启),并重启php服务';
  24. die();
  25. }
  26. if(!extension_loaded('gd')){
  27. echo '你还未安装(开启)PHP的【gd】扩展,该扩展主要用于验证码,请先安装(开启),并重启php服务';
  28. die();
  29. }
  30. }
  31. public function index()
  32. {
  33. View::assign('TP_VERSION',\think\facade\App::version());
  34. return view('step1');
  35. }
  36. public function step2()
  37. {
  38. if (class_exists('pdo')) {
  39. $data['pdo'] = 1;
  40. } else {
  41. $data['pdo'] = 0;
  42. }
  43. if (extension_loaded('pdo_mysql')) {
  44. $data['pdo_mysql'] = 1;
  45. } else {
  46. $data['pdo_mysql'] = 0;
  47. }
  48. if (extension_loaded('curl')) {
  49. $data['curl'] = 1;
  50. } else {
  51. $data['curl'] = 0;
  52. }
  53. if (ini_get('file_uploads')) {
  54. $data['upload_size'] = ini_get('upload_max_filesize');
  55. } else {
  56. $data['upload_size'] = 0;
  57. }
  58. if (function_exists('session_start')) {
  59. $data['session'] = 1;
  60. } else {
  61. $data['session'] = 0;
  62. }
  63. return view('', ['data' => $data]);
  64. }
  65. public function step3()
  66. {
  67. return view();
  68. }
  69. public function install()
  70. {
  71. $data = get_params();
  72. try {
  73. validate(InstallCheck::class)->check($data);
  74. } catch (ValidateException $e) {
  75. // 验证失败 输出错误信息
  76. return to_assign(1, $e->getError());
  77. }
  78. $dbName = $data['DB_NAME'];
  79. //验证表是否存在
  80. try {
  81. // 连接数据库
  82. $link = @new mysqli("{$data['DB_HOST']}:{$data['DB_PORT']}", $data['DB_USER'], $data['DB_PWD']);
  83. } catch (\Exception $e) {
  84. // 这是进行异常捕获,创建数据库
  85. $error = $e->getMessage();
  86. return to_assign(1, '数据库链接失败:' . $error);die;
  87. }
  88. // 获取错误信息
  89. $error = $link->connect_error;
  90. if (!is_null($error)) {
  91. // 转义防止和alert中的引号冲突
  92. $error = addslashes($error);
  93. return to_assign(1, '数据库链接失败:' . $error);die;
  94. }
  95. // 设置字符集
  96. $link->query("SET NAMES 'utf8mb4'");
  97. //验证表是否存在
  98. try {
  99. // 这里是主体代码
  100. $isDB=$link->query('SHOW TABLES LIKE '."'".$dbName."'");
  101. if(!$isDB){
  102. //创建数据库并选中
  103. $sql = "CREATE DATABASE IF NOT EXISTS `{$dbName}` DEFAULT CHARACTER SET utf8mb4";
  104. $link->query($sql);
  105. }
  106. } catch (\Exception $e) {
  107. // 这是进行异常捕获,创建数据库并选中
  108. $error = $e->getMessage();
  109. $sql = "CREATE DATABASE IF NOT EXISTS `{$dbName}` DEFAULT CHARACTER SET utf8mb4";
  110. $link->query($sql);
  111. }
  112. $link->select_db($dbName);
  113. // 导入sql数据并创建表
  114. $fqcms_sql = file_get_contents(CMS_ROOT . '/app/install/data/gougucms.sql');
  115. $sql_array = preg_split("/;[\r\n]+/", str_replace("cms_", $data['DB_PREFIX'], $fqcms_sql));
  116. foreach ($sql_array as $k => $v) {
  117. if (!empty($v)) {
  118. $link->query($v);
  119. }
  120. }
  121. $isTable = $link->query('SHOW TABLES LIKE "'.$data['DB_PREFIX'] . 'admin"');
  122. if(!$isTable){
  123. return to_assign(1, '创建数据库表失败,请检查是否有创建权限!');
  124. }
  125. //插入管理员信息
  126. $username = $data['username'];
  127. $password = $data['password'];
  128. $nickname = '超级管理员';
  129. $thumb = '/static/admin/images/';
  130. $salt = set_salt(20);
  131. $password = set_password($password, $salt);
  132. $create_time = time();
  133. $update_time = time();
  134. $create_admin_sql = "INSERT INTO " . $data['DB_PREFIX'] . "admin " .
  135. "(username,pwd, nickname,thumb,salt,did,position_id,create_time,update_time) "
  136. . "VALUES "
  137. . "('$username','$password','$nickname','$thumb','$salt',1,1,'$create_time','$update_time')";
  138. if (!$link->query($create_admin_sql)) {
  139. return to_assign(1, '创建管理员信息失败,请重试安装');
  140. }
  141. $link->close();
  142. $db_str = "<?php
  143. return [
  144. // 默认使用的数据库连接配置
  145. 'default' => 'mysql',
  146. // 自定义时间查询规则
  147. 'time_query_rule' => [],
  148. // 自动写入时间戳字段
  149. // true为自动识别类型 false关闭
  150. // 字符串则明确指定时间字段类型 支持 int timestamp datetime date
  151. 'auto_timestamp' => true,
  152. // 时间字段取出后的默认时间格式
  153. 'datetime_format' => 'Y-m-d H:i:s',
  154. // 数据库连接配置信息
  155. 'connections' => [
  156. 'mysql' => [
  157. // 数据库类型
  158. 'type' => 'mysql',
  159. // 服务器地址
  160. 'hostname' => '{$data['DB_HOST']}',
  161. // 数据库名
  162. 'database' => '{$data['DB_NAME']}',
  163. // 用户名
  164. 'username' => '{$data['DB_USER']}',
  165. // 密码
  166. 'password' => '{$data['DB_PWD']}',
  167. // 端口
  168. 'hostport' => '{$data['DB_PORT']}',
  169. // 数据库表前缀
  170. 'prefix' => '{$data['DB_PREFIX']}',
  171. // 数据库连接参数
  172. 'params' => [],
  173. // 数据库编码默认采用utf8mb4
  174. 'charset' => 'utf8mb4',
  175. // 数据库调试模式
  176. 'debug' => false,
  177. // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
  178. 'deploy' => 0,
  179. // 数据库读写是否分离 主从式有效
  180. 'rw_separate' => false,
  181. // 读写分离后 主服务器数量
  182. 'master_num' => 1,
  183. // 指定从服务器序号
  184. 'slave_no' => '',
  185. // 是否严格检查字段是否存在
  186. 'fields_strict' => true,
  187. // 是否需要断线重连
  188. 'break_reconnect' => false,
  189. // 监听SQL
  190. 'trigger_sql' => true,
  191. // 开启字段缓存
  192. 'fields_cache' => false,
  193. ],
  194. ],
  195. ];";
  196. // 创建数据库配置文件
  197. if (false == file_put_contents(CMS_ROOT . "config/database.php", $db_str)) {
  198. return to_assign(1, '创建数据库配置文件失败,请检查目录权限');
  199. }
  200. if (false == file_put_contents(CMS_ROOT . "config/install.lock", '勾股CMS安装鉴定文件,请勿删除!!!!!此次安装时间为:' . date('Y-m-d H:i:s', time()))) {
  201. return to_assign(1, '创建安装鉴定文件失败,请检查目录权限');
  202. }
  203. return to_assign();
  204. }
  205. }