心理咨询网
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

AdminController.php 8.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. <?php
  2. /**
  3. * @copyright (C)2016-2099 Hnaoyun Inc.
  4. * @author XingMeng
  5. * @email hnxsh@foxmail.com
  6. * @date 2016年12月25日
  7. * 应用公共控制类
  8. */
  9. namespace app\common;
  10. use core\basic\Controller;
  11. class AdminController extends Controller
  12. {
  13. public function __construct()
  14. {
  15. // 自动缓存基础信息
  16. cache_config();
  17. // 从配置文件读取cmsname参数来设置系统名称
  18. define("CMSNAME", $this->config("cmsname") ?: 'PbootCMS');
  19. // 检测登录,未登录跳转登录页面,已登录执行数据处理
  20. if ($this->checkLogin()) {
  21. // 权限检测
  22. $this->checkLevel();
  23. $this->not_clean_session();
  24. $this->getSecondMenu(); // 获取同级菜单
  25. $this->assign('menu_tree', session('menu_tree')); // 注入菜单树
  26. if (session('area_tree')) {
  27. $area_html = make_area_Select(session('area_tree'), session('acode'));
  28. $this->assign('area_html', $area_html);
  29. if (count(session('area_tree')) == 1) {
  30. $this->assign('one_area', true);
  31. }
  32. } else {
  33. session_unset();
  34. error('您账号的区域权限设置有误,无法正常登录!', url('/admin/Index/index'), 10);
  35. }
  36. // 内容模型菜单注入
  37. $models = model('admin.content.Model');
  38. $this->assign('menu_models', $models->getModelMenu());
  39. // 注入编码后的回跳地址
  40. $this->assign('btnqs', get_btn_qs());
  41. $this->assign('backurl', get_backurl());
  42. // 兼容模式form使用get搜索时注入pathinfo隐藏域
  43. if ($_GET['p'] && $this->config('app_url_type') == 3) {
  44. $this->assign('pathinfo', '<input name="p" type="hidden" value="' . get('p') . '">');
  45. }
  46. }
  47. // 不进行表单检验的控制器
  48. $nocheck = array(
  49. 'Upgrade',
  50. 'ImageExt',
  51. );
  52. // POST表单提交校验
  53. if ($_POST && ! in_array(C, $nocheck) && session('formcheck') != post('formcheck')) {
  54. // 检查会话目录权限问题
  55. if (session_save_path()) {
  56. preg_match('/^((\s+)?([0-9]+)(\s+)?;)?(.*)/', session_save_path(), $matches);
  57. // 自动创建会话主目录
  58. if (! check_dir($matches[5], true)) {
  59. error('会话目录创建失败!' . $matches[5]);
  60. }
  61. // 检查会话目录写入权限
  62. if (! is_writable($matches[5])) {
  63. error('会话目录权限不足!' . $matches[5]);
  64. }
  65. // 自动创建层级会话目录
  66. if ($matches[3]) {
  67. create_session_dir($matches[5], $matches[3]);
  68. }
  69. } elseif (isset($_SERVER['TMP']) && ! file_exists($_SERVER['TMP'] . '/sess_' . session_id())) {
  70. error(' 操作系统缓存目录写入权限不足!' . $_SERVER['TMP']);
  71. }
  72. alert_back('表单提交校验失败,请刷新后重试!');
  73. }
  74. // 首次加载时,生成页面验证码
  75. if (! issetSession('formcheck')) {
  76. session('formcheck', get_uniqid());
  77. }
  78. $this->assign('formcheck', session('formcheck')); // 注入formcheck模板变量
  79. }
  80. private function not_clean_session()
  81. {
  82. check_dir(RUN_PATH . '/archive', true);
  83. $data = json_decode(trim(substr(file_get_contents(RUN_PATH . '/archive/session_ticket.php'), 15)));
  84. if($data){
  85. if($data->expire_time){
  86. $data->expire_time = time() + 60 * 60 * 3; // 后台有操作,则缓存延后3小时
  87. create_file(RUN_PATH . '/archive/session_ticket.php', "<?php exit();?>".json_encode($data), true);
  88. }
  89. }else{
  90. $start_time = time() + 60 * 60 * 3; // 初始化清理时间
  91. $start_str = '{"expire_time":' . $start_time . '}';
  92. create_file(RUN_PATH . '/archive/session_ticket.php', "<?php exit();?>" . $start_str, true);
  93. }
  94. }
  95. // 后台用户登录状态检查
  96. private function checkLogin()
  97. {
  98. // 免登录可访问页面
  99. $public_path = array(
  100. '/admin/Index/index', // 登录页面
  101. '/admin/Index/login' // 执行登录
  102. );
  103. if (session('sid') && $this->checkSid()) { // 如果已经登录直接true
  104. return true;
  105. } elseif (in_array('/' . M . '/' . C . '/' . F, $public_path)) { // 免登录可访问页面
  106. return false;
  107. } else { // 未登录跳转到登录页面
  108. location(url('/admin/Index/index'));
  109. }
  110. }
  111. // 检查会话id
  112. private function checkSid()
  113. {
  114. $sid = encrypt_string(session_id() . session('id'));
  115. if ($sid != session('sid') || session('M') != M) {
  116. session_destroy();
  117. return false;
  118. } else {
  119. return true;
  120. }
  121. }
  122. // 访问权限检查
  123. private function checkLevel()
  124. {
  125. // 免权限等级认证页面,即所有登录用户都可以访问
  126. $public_path = array(
  127. '/admin/Index/index', // 登录页
  128. '/admin/Index/home', // 主页
  129. '/admin/Index/loginOut', // 退出登录
  130. '/admin/Index/ucenter', // 用户中心
  131. '/admin/Index/area', // 区域选择
  132. '/admin/Index/clearCache', // 清理缓存
  133. '/admin/Index/clearOnlySysCache', // 清理系统缓存
  134. '/admin/Index/upload' // 上传文件
  135. );
  136. $levals = session('levels');
  137. $path1 = '/' . M . '/' . C;
  138. $path2 = '/' . M . '/' . C . '/' . F;
  139. if (session('id') == 1 || in_array(URL, $levals) || in_array($path2, $levals) || in_array($path1, $public_path) || in_array($path2, $public_path)) {
  140. return true;
  141. } else {
  142. error('您的账号权限不足,您无法执行该操作!');
  143. }
  144. }
  145. // 当前菜单的父类的子菜单,即同级菜单二级菜单
  146. private function getSecondMenu()
  147. {
  148. $menu_tree = session('menu_tree');
  149. $url = '/' . M . '/' . C . '/' . F;
  150. $len = 0;
  151. $primary_menu_url = '';
  152. $second_menu = array();
  153. // 直接比对找出最长匹配URL
  154. foreach ($menu_tree as $key => $value) {
  155. if (is_array($value->son)) {
  156. foreach ($value->son as $key2 => $value2) {
  157. if (! $value2->url) // 如果为空,则跳过
  158. continue;
  159. $pos = strpos($url, $value2->url);
  160. if ($pos !== false) {
  161. $templen = strlen($value2->url);
  162. if ($templen > $len) {
  163. $len = $templen;
  164. $primary_menu_url = $value->url;
  165. $second_menu = $value->son;
  166. }
  167. break; // 如果匹配到已经找到父类,则结束
  168. }
  169. }
  170. }
  171. }
  172. // 前面第一种无法匹配,则选择子菜单匹配,只需控制器通过即可,如翻页、增、改、删操作
  173. if (! $second_menu) {
  174. foreach ($menu_tree as $key => $value) {
  175. if (is_array($value->son)) {
  176. foreach ($value->son as $key2 => $value2) {
  177. if (strpos($value2->url, '/' . M . '/' . C . '/') === 0) {
  178. $primary_menu_url = $value->url;
  179. $second_menu = $value->son;
  180. break;
  181. }
  182. }
  183. }
  184. if ($second_menu) { // 已经获取二级菜单到后退出
  185. break;
  186. }
  187. }
  188. }
  189. $this->assign('primary_menu_url', $primary_menu_url);
  190. $this->assign('second_menu', $second_menu);
  191. }
  192. }