193 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			193 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | ||
|  | declare (strict_types = 1); | ||
|  | 
 | ||
|  | namespace app\controller; | ||
|  | 
 | ||
|  | use think\{App, Validate}; | ||
|  | use think\exception\ValidateException; | ||
|  | 
 | ||
|  | /** | ||
|  |  * 控制器基础类 | ||
|  |  */ | ||
|  | abstract class BaseController | ||
|  | { | ||
|  |     /** | ||
|  |      * Request实例 | ||
|  |      * @var \think\Request | ||
|  |      */ | ||
|  |     protected $request; | ||
|  | 
 | ||
|  |     /** | ||
|  |      * 应用实例 | ||
|  |      * @var \think\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); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * 操作成功跳转的快捷方法 | ||
|  |      * @access protected | ||
|  |      * @param  mixed     $msg 提示信息 | ||
|  |      * @param  string    $url 跳转的URL地址 | ||
|  |      * @param  mixed     $data 返回的数据 | ||
|  |      * @param  integer   $wait 跳转等待时间 | ||
|  |      * @param  array     $header 发送的Header信息 | ||
|  |      * @return void | ||
|  |      */ | ||
|  |     protected function success($msg = '', string $url = null, $data = '', int $wait = 3, array $header = []) | ||
|  |     { | ||
|  |         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/jump',$result)); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * 操作错误跳转的快捷方法 | ||
|  |      * @access protected | ||
|  |      * @param  mixed     $msg 提示信息 | ||
|  |      * @param  string    $url 跳转的URL地址 | ||
|  |      * @param  mixed     $data 返回的数据 | ||
|  |      * @param  integer   $wait 跳转等待时间 | ||
|  |      * @param  array     $header 发送的Header信息 | ||
|  |      * @return void | ||
|  |      */ | ||
|  |     protected function error($msg = '', string $url = null, $data = '', int $wait = 3) | ||
|  |     { | ||
|  |         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     $data 要返回的数据 | ||
|  |      * @param  integer   $code 返回的code | ||
|  |      * @param  mixed     $msg 提示信息 | ||
|  |      * @param  string    $type 返回数据格式 | ||
|  |      * @param  array     $header 发送的Header信息 | ||
|  |      * @return void | ||
|  |      */ | ||
|  |     protected function json($code = 0, $msg = 'ok', $data= []) | ||
|  |     { | ||
|  |         $result = [ | ||
|  |             'code' => $code, | ||
|  |             'msg'  => $msg, | ||
|  |             'time' => time(), | ||
|  |             'data' => $data | ||
|  |         ]; | ||
|  |         return json($result); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * URL重定向 | ||
|  |      * @access protected | ||
|  |      * @param  string         $url 跳转的URL表达式 | ||
|  |      * @param  array|integer  $params 其它URL参数 | ||
|  |      * @param  integer        $code http code | ||
|  |      * @param  array          $with 隐式传参 | ||
|  |      * @return void | ||
|  |      */ | ||
|  |     protected function redirect($url) | ||
|  |     { | ||
|  |         if(!is_string($url)){ | ||
|  |             $url = $url->__toString(); | ||
|  |         } | ||
|  |         return redirect($url); | ||
|  |     } | ||
|  | } |