Index.php 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <?php
  2. /**
  3. +-----------------------------------------------------------------------------------------------
  4. * GouGuOPEN [ 左手研发,右手开源,未来可期!]
  5. +-----------------------------------------------------------------------------------------------
  6. * @Copyright (c) 2021~2024 http://www.gouguoa.com All rights reserved.
  7. +-----------------------------------------------------------------------------------------------
  8. * @Licensed 勾股OA,开源且可免费使用,但并不是自由软件,未经授权许可不能去除勾股OA的相关版权信息
  9. +-----------------------------------------------------------------------------------------------
  10. * @Author 勾股工作室 <hdm58@qq.com>
  11. +-----------------------------------------------------------------------------------------------
  12. */
  13. declare (strict_types = 1);
  14. namespace app\install\controller;
  15. use app\install\validate\InstallCheck;
  16. use mysqli;
  17. use think\exception\ValidateException;
  18. use think\facade\View;
  19. class Index
  20. {
  21. public function __construct()
  22. {
  23. // 检测是否安装过
  24. if (is_installed()) {
  25. if(Request()->action()!='step4'){
  26. echo '你已经安装过勾股OA系统!如需重新安装,请删除“config/install.lock”文件';
  27. die();
  28. }
  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 step4()
  70. {
  71. \think\facade\Cache::clear();
  72. $domain = get_system_config('web','domain');
  73. return view('', ['domain' => $domain]);
  74. }
  75. public function install()
  76. {
  77. $data = get_params();
  78. try {
  79. validate(InstallCheck::class)->check($data);
  80. } catch (ValidateException $e) {
  81. // 验证失败 输出错误信息
  82. return to_assign(1, $e->getError());
  83. }
  84. $dbName = $data['DB_NAME'];
  85. //验证表是否存在
  86. try {
  87. // 连接数据库
  88. $link = @new mysqli("{$data['DB_HOST']}:{$data['DB_PORT']}", $data['DB_USER'], $data['DB_PWD']);
  89. } catch (\Exception $e) {
  90. // 这是进行异常捕获,创建数据库
  91. $error = $e->getMessage();
  92. return to_assign(1, '数据库链接失败:' . $error);die;
  93. }
  94. // 获取错误信息
  95. $error = $link->connect_error;
  96. if (!is_null($error)) {
  97. // 转义防止和alert中的引号冲突
  98. $error = addslashes($error);
  99. return to_assign(1, '数据库链接失败:' . $error);die;
  100. }
  101. // 设置字符集
  102. $link->query("SET NAMES 'utf8mb4'");
  103. //验证表是否存在
  104. try {
  105. // 这里是主体代码
  106. $isDB=$link->query('SHOW TABLES LIKE '."'".$dbName."'");
  107. if(!$isDB){
  108. //创建数据库并选中
  109. $sql = "CREATE DATABASE IF NOT EXISTS `{$dbName}` DEFAULT CHARACTER SET utf8mb4";
  110. $link->query($sql);
  111. }
  112. } catch (\Exception $e) {
  113. // 这是进行异常捕获,创建数据库并选中
  114. $error = $e->getMessage();
  115. $sql = "CREATE DATABASE IF NOT EXISTS `{$dbName}` DEFAULT CHARACTER SET utf8mb4";
  116. $link->query($sql);
  117. }
  118. $link->select_db($dbName);
  119. // 导入sql数据并创建表
  120. $oa_sql = file_get_contents(CMS_ROOT . '/app/install/data/gouguoa.sql');
  121. $sql_array = preg_split("/;[\r\n]+/", str_replace("oa_", $data['DB_PREFIX'], $oa_sql));
  122. foreach ($sql_array as $k => $v) {
  123. if (!empty($v)) {
  124. try {
  125. //var_dump($v);
  126. $link->query($v);
  127. } catch (\Exception $e) {
  128. return to_assign(1, '数据写入失败,请联系官方!');
  129. break;
  130. }
  131. }
  132. }
  133. $isTable = $link->query('SHOW TABLES LIKE "'.$data['DB_PREFIX'] . 'admin"');
  134. if(!$isTable){
  135. return to_assign(1, '创建数据库表失败,请检查是否有创建权限!');
  136. }
  137. //插入管理员信息
  138. $username = get_params('username');
  139. $password = get_params('password');
  140. $nickname = '超级员工';
  141. $name = '超级员工';
  142. $thumb = '/static/home/images/icon.png';
  143. $salt = set_salt(20);
  144. $password = set_password($password, $salt);
  145. $now_time = time();
  146. $create_admin_sql = "INSERT INTO " . $data['DB_PREFIX'] . "admin" .
  147. "(username,salt,pwd,name,nickname,did,position_id,sex,mobile,email,type,thumb,entry_time,create_time,update_time,auth_did)"
  148. . "VALUES "
  149. . "('$username','$salt','$password','$name','$nickname',1,1,1,'13800138000','gouguoa@gougucms.com',1,'$thumb','$now_time','$now_time','$now_time',10)";
  150. if (!$link->query($create_admin_sql)) {
  151. return to_assign(1, '创建管理员信息失败');
  152. }
  153. $link->close();
  154. $db_str = "<?php
  155. return [
  156. // 默认使用的数据库连接配置
  157. 'default' => 'mysql',
  158. // 自定义时间查询规则
  159. 'time_query_rule' => [],
  160. // 自动写入时间戳字段
  161. // true为自动识别类型 false关闭
  162. // 字符串则明确指定时间字段类型 支持 int timestamp datetime date
  163. 'auto_timestamp' => true,
  164. // 时间字段取出后的默认时间格式
  165. 'datetime_format' => 'Y-m-d H:i:s',
  166. // 数据库连接配置信息
  167. 'connections' => [
  168. 'mysql' => [
  169. // 数据库类型
  170. 'type' => 'mysql',
  171. // 服务器地址
  172. 'hostname' => '{$data['DB_HOST']}',
  173. // 数据库名
  174. 'database' => '{$data['DB_NAME']}',
  175. // 用户名
  176. 'username' => '{$data['DB_USER']}',
  177. // 密码
  178. 'password' => '{$data['DB_PWD']}',
  179. // 端口
  180. 'hostport' => '{$data['DB_PORT']}',
  181. // 数据库表前缀
  182. 'prefix' => '{$data['DB_PREFIX']}',
  183. // 数据库连接参数
  184. 'params' => [],
  185. // 数据库编码默认采用utf8mb4
  186. 'charset' => 'utf8mb4',
  187. // 数据库调试模式
  188. 'debug' => false,
  189. // 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
  190. 'deploy' => 0,
  191. // 数据库读写是否分离 主从式有效
  192. 'rw_separate' => false,
  193. // 读写分离后 主服务器数量
  194. 'master_num' => 1,
  195. // 指定从服务器序号
  196. 'slave_no' => '',
  197. // 是否严格检查字段是否存在
  198. 'fields_strict' => true,
  199. // 是否需要断线重连
  200. 'break_reconnect' => false,
  201. // 监听SQL
  202. 'trigger_sql' => true,
  203. // 开启字段缓存
  204. 'fields_cache' => false,
  205. ],
  206. ],
  207. ];";
  208. // 创建数据库配置文件
  209. if (false == file_put_contents(CMS_ROOT . "config/database.php", $db_str)) {
  210. return to_assign(1, '创建数据库配置文件失败,请检查目录权限');
  211. }
  212. if (false == file_put_contents(CMS_ROOT . "config/install.lock", '勾股OA安装鉴定文件,请勿删除!!!!!此次安装时间为:' . date('Y-m-d H:i:s', time()))) {
  213. return to_assign(1, '创建安装鉴定文件失败,请检查目录权限');
  214. }
  215. return to_assign(0,'安装完成');
  216. }
  217. }