241 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
			
		
		
	
	
			241 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
<?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);
 | 
						|
    }
 | 
						|
} |