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\worker;
  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_worker = [];
  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. $has_access_worker = Session::has('access_worker');
  64. if ( $has_access_worker ) {
  65. $this->access_worker = Session::get('access_worker');
  66. }else{
  67. echo '<script language="javascript" type="text/javascript"> top.location.href="/worker.php/login/index"; </script>';
  68. exit(json_encode(array(
  69. 'code' => 1001,
  70. 'msg' => "You do not have permission to access."
  71. )));
  72. }
  73. }
  74. /**
  75. * 验证数据
  76. * @access protected
  77. * @param array $data 数据
  78. * @param string|array $validate 验证器名或者验证规则数组
  79. * @param array $message 提示信息
  80. * @param bool $batch 是否批量验证
  81. * @return array|string|true
  82. * @throws ValidateException
  83. */
  84. protected function validate(array $data, $validate, array $message = [], bool $batch = false)
  85. {
  86. if (is_array($validate)) {
  87. $v = new Validate();
  88. $v->rule($validate);
  89. } else {
  90. if (strpos($validate, '.')) {
  91. // 支持场景
  92. list($validate, $scene) = explode('.', $validate);
  93. }
  94. $class = false !== strpos($validate, '\\') ? $validate : $this->app->parseClass('validate', $validate);
  95. $v = new $class();
  96. if (!empty($scene)) {
  97. $v->scene($scene);
  98. }
  99. }
  100. $v->message($message);
  101. // 是否批量验证
  102. if ($batch || $this->batchValidate) {
  103. $v->batch(true);
  104. }
  105. return $v->failException(true)->check($data);
  106. }
  107. protected function dealEqualInput($result ,$equal_array)
  108. {
  109. foreach ($equal_array as $k => $v) {
  110. $value = input($v);
  111. if (!empty($value)) {
  112. $result[] = [is_numeric($k) ? $v : $k,'=',$value];
  113. }
  114. }
  115. return $result;
  116. }
  117. protected function dealLikeInput($result,$like_array)
  118. {
  119. foreach ($like_array as $k => $v) {
  120. $value = input($v);
  121. if (!empty($value)) {
  122. $result[] = [is_numeric($k) ? $v : $k,'like',"%{$value}%"];
  123. }
  124. }
  125. return $result;
  126. }
  127. }