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);
|
||
|
}
|
||
|
}
|