BaseController.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. <?php
  2. declare(strict_types=1);
  3. namespace app;
  4. use think\App;
  5. use think\exception\ValidateException;
  6. use think\Validate;
  7. use think\facade\View;
  8. use think\exception\HttpResponseException;
  9. use think\Response;
  10. /**
  11. * 控制器基础类
  12. */
  13. abstract class BaseController
  14. {
  15. /**
  16. * Request实例
  17. * @var \think\Request
  18. */
  19. protected $request;
  20. /**
  21. * 应用实例
  22. * @var \think\App
  23. */
  24. protected $app;
  25. /**
  26. * 是否批量验证
  27. * @var bool
  28. */
  29. protected $batchValidate = false;
  30. /**
  31. * 控制器中间件
  32. * @var array
  33. */
  34. protected $middleware = [];
  35. /**
  36. * 构造方法
  37. * @access public
  38. * @param App $app 应用对象
  39. */
  40. public function __construct(App $app)
  41. {
  42. $this->app = $app;
  43. $this->request = $this->app->request;
  44. View::assign('ick_kci', checkSecurity());
  45. // 控制器初始化
  46. $this->initialize();
  47. }
  48. // 初始化
  49. protected function initialize()
  50. {
  51. }
  52. /**
  53. * 验证数据
  54. * @access protected
  55. * @param array $data 数据
  56. * @param string|array $validate 验证器名或者验证规则数组
  57. * @param array $message 提示信息
  58. * @param bool $batch 是否批量验证
  59. * @return array|string|true
  60. * @throws ValidateException
  61. */
  62. protected function validate(array $data, $validate, array $message = [], bool $batch = false)
  63. {
  64. if (is_array($validate)) {
  65. $v = new Validate();
  66. $v->rule($validate);
  67. } else {
  68. if (strpos($validate, '.')) {
  69. // 支持场景
  70. [$validate, $scene] = explode('.', $validate);
  71. }
  72. $class = false !== strpos($validate, '\\') ? $validate : $this->app->parseClass('validate', $validate);
  73. $v = new $class();
  74. if (!empty($scene)) {
  75. $v->scene($scene);
  76. }
  77. }
  78. $v->message($message);
  79. // 是否批量验证
  80. if ($batch || $this->batchValidate) {
  81. $v->batch(true);
  82. }
  83. return $v->failException(true)->check($data);
  84. }
  85. /**
  86. * 操作成功跳转的快捷方法
  87. * @access protected
  88. * @param mixed $msg 提示信息
  89. * @param string $url 跳转的URL地址
  90. * @param mixed $data 返回的数据
  91. * @param integer $wait 跳转等待时间
  92. * @param array $header 发送的Header信息
  93. * @return void
  94. */
  95. protected function success($msg = '', string $url = null, $data = '', int $wait = 3, array $header = [])
  96. {
  97. if (is_null($url) && isset($_SERVER["HTTP_REFERER"])) {
  98. $url = $_SERVER["HTTP_REFERER"];
  99. } elseif ($url) {
  100. $url = (string)$url;
  101. $url = (strpos($url, '://') || 0 === strpos($url, '/')) ? $url : (string)$this->app->route->buildUrl($url);
  102. }
  103. $result = [
  104. 'code' => 1,
  105. 'msg' => $msg,
  106. 'data' => $data,
  107. 'url' => $url,
  108. 'wait' => $wait,
  109. ];
  110. $type = $this->getResponseType();
  111. // 把跳转模板的渲染下沉,这样在 response_send 行为里通过getData()获得的数据是一致性的格式
  112. if ('html' == strtolower($type)) {
  113. $type = 'view';
  114. $response = Response::create($this->app->config->get('jump.dispatch_success_tmpl'), $type)->assign($result)->header($header);
  115. } else {
  116. $response = Response::create($result, $type)->header($header);
  117. }
  118. throw new HttpResponseException($response);
  119. }
  120. /**
  121. * 操作错误跳转的快捷方法
  122. * @access protected
  123. * @param mixed $msg 提示信息
  124. * @param string $url 跳转的URL地址
  125. * @param mixed $data 返回的数据
  126. * @param integer $wait 跳转等待时间
  127. * @param array $header 发送的Header信息
  128. * @return void
  129. */
  130. protected function error($msg = '', string $url = null, $data = '', int $wait = 3, array $header = [])
  131. {
  132. if (is_null($url)) {
  133. $url = $this->request->isAjax() ? '' : 'javascript:history.back(-1);';
  134. } elseif ($url) {
  135. $url = (string)$url;
  136. $url = (strpos($url, '://') || 0 === strpos($url, '/')) ? $url : (string)$this->app->route->buildUrl($url);
  137. }
  138. $result = [
  139. 'code' => 0,
  140. 'msg' => $msg,
  141. 'data' => $data,
  142. 'url' => $url,
  143. 'wait' => $wait,
  144. ];
  145. $type = $this->getResponseType();
  146. if ('html' == strtolower($type)) {
  147. $type = 'view';
  148. $response = Response::create($this->app->config->get('jump.dispatch_error_tmpl'), $type)->assign($result)->header($header);
  149. } else {
  150. $response = Response::create($result, $type)->header($header);
  151. }
  152. throw new HttpResponseException($response);
  153. }
  154. /**
  155. * URL重定向
  156. * @access protected
  157. * @param string $url 跳转的URL表达式
  158. * @param integer $code http code
  159. * @param array $with 隐式传参
  160. * @return void
  161. */
  162. protected function redirect($url, $params = [], $code = 302, $with = [])
  163. {
  164. $url = (string)$url;
  165. $url = (strpos($url, '://') || 0 === strpos($url, '/')) ? $url : (string)$this->app->route->buildUrl($url, $params);
  166. $response = Response::create($url, 'redirect');
  167. $response->code($code)->with($with);
  168. throw new HttpResponseException($response);
  169. }
  170. /**
  171. * 获取当前的 response 输出类型
  172. * @access protected
  173. * @return string
  174. */
  175. protected function getResponseType()
  176. {
  177. return request()->isAjax()
  178. ? 'json'
  179. : 'html';
  180. }
  181. }