241 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			241 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | ||
|  | declare (strict_types=1); | ||
|  | 
 | ||
|  | namespace app\controller; | ||
|  | 
 | ||
|  | use think\{App, Request, response\Json, response\Redirect, Validate}; | ||
|  | use Exception; | ||
|  | use think\exception\ValidateException; | ||
|  | 
 | ||
|  | /** | ||
|  |  * 控制器基础类 | ||
|  |  */ | ||
|  | abstract class BaseController | ||
|  | { | ||
|  |     /** | ||
|  |      * 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((string) url('error/jump', $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/jump', $result)); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * 返回封装后的API数据到客户端 | ||
|  |      * 以json格式抛出异常 | ||
|  |      * @access protected | ||
|  |      * @param  mixed  $code  返回的code | ||
|  |      * @param  mixed  $msg  提示信息 | ||
|  |      * @param  mixed  $data  要返回的数据 | ||
|  |      * @return Json | ||
|  |      */ | ||
|  |     protected function json($code = 0, $msg = 'ok', $data = []): Json | ||
|  |     { | ||
|  |         $result = [ | ||
|  |             'code' => $code, | ||
|  |             'msg'  => $msg, | ||
|  |             'time' => time(), | ||
|  |             'data' => $data | ||
|  |         ]; | ||
|  |         return json($result); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * URL重定向 | ||
|  |      * @access protected | ||
|  |      * @param  mixed  $url  跳转的URL表达式 | ||
|  |      * @return Redirect | ||
|  |      */ | ||
|  |     protected function redirect($url): Redirect | ||
|  |     { | ||
|  |         if (!is_string($url)) { | ||
|  |             $url = $url->__toString(); | ||
|  |         } | ||
|  |         return redirect($url); | ||
|  |     } | ||
|  | } |