BaseController.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkPHP [ WE CAN DO IT JUST THINK ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2006~2019 http://thinkphp.cn All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
  8. // +----------------------------------------------------------------------
  9. // | Author: liu21st <liu21st@gmail.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types = 1);
  12. namespace app\admin;
  13. use think\App;
  14. use think\exception\ValidateException;
  15. use think\Validate;
  16. use think\facade\Session;
  17. /**
  18. * 控制器基础类
  19. */
  20. abstract class BaseController
  21. {
  22. /**
  23. * Request实例
  24. * @var \think\Request
  25. */
  26. protected $request;
  27. /**
  28. * 应用实例
  29. * @var \think\App
  30. */
  31. protected $app;
  32. /**
  33. * 是否批量验证
  34. * @var bool
  35. */
  36. protected $batchValidate = false;
  37. /**
  38. * 控制器中间件
  39. * @var array
  40. */
  41. protected $middleware = [];
  42. /**
  43. * 控制器中间件
  44. * @var array
  45. */
  46. protected $access_admin = [];
  47. /**
  48. * 构造方法
  49. * @access public
  50. * @param App $app 应用对象
  51. */
  52. public function __construct(App $app)
  53. {
  54. $this->app = $app;
  55. $this->request = $this->app->request;
  56. // 控制器初始化
  57. $this->initialize();
  58. }
  59. // 初始化
  60. protected function initialize()
  61. {
  62. // 验证登陆信息
  63. $access_admin = Session::has('access_admin');
  64. if ( $access_admin ) {
  65. }else{
  66. echo '<script language="javascript" type="text/javascript"> top.location.href="/admin.php/login/index"; </script>';
  67. exit(json_encode(array(
  68. 'code' => 1001,
  69. 'msg' => "You do not have permission to access."
  70. )));
  71. }
  72. }
  73. /**
  74. * 验证数据
  75. * @access protected
  76. * @param array $data 数据
  77. * @param string|array $validate 验证器名或者验证规则数组
  78. * @param array $message 提示信息
  79. * @param bool $batch 是否批量验证
  80. * @return array|string|true
  81. * @throws ValidateException
  82. */
  83. protected function validate(array $data, $validate, array $message = [], bool $batch = false)
  84. {
  85. if (is_array($validate)) {
  86. $v = new Validate();
  87. $v->rule($validate);
  88. } else {
  89. if (strpos($validate, '.')) {
  90. // 支持场景
  91. list($validate, $scene) = explode('.', $validate);
  92. }
  93. $class = false !== strpos($validate, '\\') ? $validate : $this->app->parseClass('validate', $validate);
  94. $v = new $class();
  95. if (!empty($scene)) {
  96. $v->scene($scene);
  97. }
  98. }
  99. $v->message($message);
  100. // 是否批量验证
  101. if ($batch || $this->batchValidate) {
  102. $v->batch(true);
  103. }
  104. return $v->failException(true)->check($data);
  105. }
  106. protected function dealEqualInput($result ,$equal_array)
  107. {
  108. foreach ($equal_array as $k => $v) {
  109. $value = input($v);
  110. if (!empty($value)) {
  111. $result[] = [is_numeric($k) ? $v : $k,'=',$value];
  112. }
  113. }
  114. return $result;
  115. }
  116. protected function dealLikeInput($result,$like_array)
  117. {
  118. foreach ($like_array as $k => $v) {
  119. $value = input($v);
  120. if (!empty($value)) {
  121. $result[] = [is_numeric($k) ? $v : $k,'like',"%{$value}%"];
  122. }
  123. }
  124. return $result;
  125. }
  126. }