BaseController.php 5.9 KB

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