254 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			254 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
| <?php
 | |
| declare (strict_types=1);
 | |
| 
 | |
| namespace app\controller;
 | |
| 
 | |
| use think\{App, Request, response\Json, response\Redirect, response\View, Validate};
 | |
| use Exception;
 | |
| use think\exception\ValidateException;
 | |
| 
 | |
| /**
 | |
|  * 控制器基础类
 | |
|  */
 | |
| abstract class BaseController
 | |
| {
 | |
|     /**
 | |
|      * 无需登录的方法,同时也就不需要鉴权了
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     protected $noNeedLogin = [];
 | |
| 
 | |
|     /**
 | |
|      * 无需鉴权的方法,但需要登录
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     protected $noNeedRight = [];
 | |
| 
 | |
|     /**
 | |
|      * Request实例
 | |
|      * @var Request
 | |
|      */
 | |
|     protected $request;
 | |
| 
 | |
|     /**
 | |
|      * 应用实例
 | |
|      * @var App
 | |
|      */
 | |
|     protected $app;
 | |
| 
 | |
|     /**
 | |
|      * 是否批量验证
 | |
|      * @var bool
 | |
|      */
 | |
|     protected $batchValidate = false;
 | |
| 
 | |
|     /**
 | |
|      * 控制器中间件
 | |
|      * @var array
 | |
|      */
 | |
|     protected $middleware = [];
 | |
| 
 | |
|     /**
 | |
|      * 构造方法
 | |
|      * @access public
 | |
|      * @param  App  $app  应用对象
 | |
|      */
 | |
|     public function __construct(App $app)
 | |
|     {
 | |
|         $this->app     = $app;
 | |
|         $this->request = $this->app->request;
 | |
| 
 | |
|         // 控制器初始化
 | |
|         $this->initialize();
 | |
|     }
 | |
| 
 | |
|     // 初始化
 | |
|     protected function initialize()
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 验证数据
 | |
|      * @access protected
 | |
|      * @param  array  $data  数据
 | |
|      * @param  string|array  $validate  验证器名或者验证规则数组
 | |
|      * @param  array  $message  提示信息
 | |
|      * @param  bool  $batch  是否批量验证
 | |
|      * @return array|string|true
 | |
|      * @throws ValidateException
 | |
|      */
 | |
|     protected function validate(array $data, $validate, array $message = [], bool $batch = false)
 | |
|     {
 | |
|         if (is_array($validate)) {
 | |
|             $v = new Validate();
 | |
|             $v->rule($validate);
 | |
|         } else {
 | |
|             if (strpos($validate, '.')) {
 | |
|                 // 支持场景
 | |
|                 list($validate, $scene) = explode('.', $validate);
 | |
|             }
 | |
|             $class = false !== strpos($validate, '\\') ? $validate : $this->app->parseClass('validate', $validate);
 | |
|             $v     = new $class();
 | |
|             if (!empty($scene)) {
 | |
|                 $v->scene($scene);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         $v->message($message);
 | |
| 
 | |
|         // 是否批量验证
 | |
|         if ($batch || $this->batchValidate) {
 | |
|             $v->batch(true);
 | |
|         }
 | |
| 
 | |
|         return $v->failException(true)->check($data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 验证器
 | |
|      *
 | |
|      * @param  array  $data
 | |
|      * @param $validate
 | |
|      * @param  array  $message
 | |
|      * @param  bool  $batch
 | |
|      * @return Json|bool
 | |
|      * @throws Exception
 | |
|      */
 | |
|     protected function validateByApi(array $data, $validate, array $message = [], bool $batch = false)
 | |
|     {
 | |
|         try {
 | |
|             $this->validate($data, $validate, $message, $batch);
 | |
|             return true;
 | |
|         } catch (ValidateException $e) {
 | |
|             $msg = $e->getMessage();
 | |
|             if ($batch) {
 | |
|                 $msg = implode(',', $e->getError());
 | |
|             }
 | |
| 
 | |
|             return $this->json(4000, $msg);
 | |
|         } catch (Exception $e) {
 | |
|             throw $e;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 验证器
 | |
|      *
 | |
|      * @param  array  $data
 | |
|      * @param $validate
 | |
|      * @param  array  $message
 | |
|      * @param  bool  $batch
 | |
|      * @return Redirect
 | |
|      * @throws Exception
 | |
|      */
 | |
|     protected function validateByView(array $data, $validate, array $message = [], bool $batch = false): Redirect
 | |
|     {
 | |
|         try {
 | |
|             $this->validate($data, $validate, $message, $batch);
 | |
|         } catch (ValidateException $e) {
 | |
|             $msg = $e->getMessage();
 | |
|             if ($batch) {
 | |
|                 $msg = implode(',', $e->getError());
 | |
|             }
 | |
| 
 | |
|             return $this->error( $msg);
 | |
|         } catch (Exception $e) {
 | |
|             throw $e;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 操作成功跳转的快捷方法
 | |
|      * @access protected
 | |
|      * @param  mixed  $msg  提示信息
 | |
|      * @param  string|null  $url  跳转的URL地址
 | |
|      * @param  mixed  $data  返回的数据
 | |
|      * @param  integer  $wait  跳转等待时间
 | |
|      * @param  array  $header  发送的Header信息
 | |
|      * @return Redirect
 | |
|      */
 | |
|     protected function success($msg = '', string $url = null, $data = '', int $wait = 3, array $header = []): Redirect
 | |
|     {
 | |
|         if (is_null($url) && isset($_SERVER["HTTP_REFERER"])) {
 | |
|             $url = $_SERVER["HTTP_REFERER"];
 | |
|         } elseif ($url) {
 | |
|             $url = (strpos($url, '://') || 0 === strpos($url, '/')) ? $url : $this->app->route->buildUrl($url);
 | |
|         }
 | |
| 
 | |
|         $result = [
 | |
|             'code' => 1,
 | |
|             'msg'  => $msg,
 | |
|             'data' => $data,
 | |
|             'url'  => $url,
 | |
|             'wait' => $wait,
 | |
|         ];
 | |
|         return $this->redirect(url('error/404', $result));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 操作错误跳转的快捷方法
 | |
|      * @access protected
 | |
|      * @param  mixed  $msg  提示信息
 | |
|      * @param  string|null  $url  跳转的URL地址
 | |
|      * @param  mixed  $data  返回的数据
 | |
|      * @param  integer  $wait  跳转等待时间
 | |
|      * @return Redirect
 | |
|      */
 | |
|     protected function error($msg = '', string $url = null, $data = '', int $wait = 3): Redirect
 | |
|     {
 | |
|         if (is_null($url)) {
 | |
|             $referer = $_SERVER['HTTP_REFERER'] ?? null;
 | |
|             if (empty($referer)) {
 | |
|                 $url = $this->request->isAjax() ? '' : '/';
 | |
|             } else {
 | |
|                 $url = $this->request->isAjax() ? '' : 'javascript:history.back(-1);';
 | |
|             }
 | |
|         } elseif ($url) {
 | |
|             $url = (strpos($url, '://') || 0 === strpos($url, '/')) ? $url : $this->app->route->buildUrl($url);
 | |
|         }
 | |
|         $result = [
 | |
|             'code' => 0,
 | |
|             'msg'  => $msg,
 | |
|             'data' => $data,
 | |
|             'url'  => $url,
 | |
|             'wait' => $wait,
 | |
|         ];
 | |
| 
 | |
|         return $this->redirect(url('error/404', $result));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 返回封装后的API数据到客户端
 | |
|      * 以json格式抛出异常
 | |
|      * @access protected
 | |
|      * @param  integer  $code  返回的code
 | |
|      * @param  mixed  $msg  提示信息
 | |
|      * @param  mixed  $data  要返回的数据
 | |
|      * @return Json
 | |
|      */
 | |
|     protected function json(int $code = 0, $msg = '操作成功', $data = []): Json
 | |
|     {
 | |
|         $result = [
 | |
|             'code' => $code,
 | |
|             'msg'  => $msg,
 | |
|             'data' => $data
 | |
|         ];
 | |
|         return json($result);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * URL重定向
 | |
|      * @access protected
 | |
|      * @param  string  $url  跳转的URL表达式
 | |
|      * @return Redirect
 | |
|      */
 | |
|     protected function redirect($url): Redirect
 | |
|     {
 | |
|         if (!is_string($url)) {
 | |
|             $url = $url->__toString();
 | |
|         }
 | |
|         return redirect($url);
 | |
|     }
 | |
| } |