mirror of
https://gitee.com/zoujingli/ThinkAdmin.git
synced 2025-05-21 14:29:15 +08:00
195 lines
5.8 KiB
PHP
195 lines
5.8 KiB
PHP
<?php
|
||
|
||
// +----------------------------------------------------------------------
|
||
// | Library for ThinkAdmin
|
||
// +----------------------------------------------------------------------
|
||
// | 版权所有 2014~2019 广州楚才信息科技有限公司 [ http://www.cuci.cc ]
|
||
// +----------------------------------------------------------------------
|
||
// | 官方网站: http://library.thinkadmin.top
|
||
// +----------------------------------------------------------------------
|
||
// | 开源协议 ( https://mit-license.org )
|
||
// +----------------------------------------------------------------------
|
||
// | github 仓库地址 :https://github.com/zoujingli/ThinkLibrary
|
||
// +----------------------------------------------------------------------
|
||
|
||
namespace library;
|
||
|
||
use library\tools\Csrf;
|
||
use think\exception\HttpResponseException;
|
||
|
||
/**
|
||
* 标准控制器基类
|
||
* --------------------------------
|
||
* Class Controller
|
||
* @package library
|
||
* --------------------------------
|
||
* @method logic\Query _query($dbQuery)
|
||
* @method array _input($data, $rule = [], $info = [])
|
||
* @method mixed _delete($dbQuery, $pkField = '', $where = [])
|
||
* @method mixed _save($dbQuery, $data = [], $pkField = '', $where = [])
|
||
* @method mixed _form($dbQuery, $tplFile = '', $pkField = '', $where = [], $data = [])
|
||
* @method array _page($dbQuery, $isPage = true, $isDisplay = true, $total = false, $limit = 0)
|
||
*/
|
||
class Controller extends \stdClass
|
||
{
|
||
|
||
/**
|
||
* 当前请求对象
|
||
* @var \think\Request
|
||
*/
|
||
public $request;
|
||
|
||
/**
|
||
* 表单CSRF验证状态
|
||
* @var boolean
|
||
*/
|
||
private $csrf = false;
|
||
|
||
/**
|
||
* Controller constructor.
|
||
*/
|
||
public function __construct()
|
||
{
|
||
$this->request = request();
|
||
if (in_array($this->request->action(), get_class_methods(__CLASS__))) {
|
||
$this->error('Access without permission.');
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Controller destruct
|
||
*/
|
||
public function __destruct()
|
||
{
|
||
$this->request = request();
|
||
$action = $this->request->action();
|
||
$method = strtolower($this->request->method());
|
||
if (method_exists($this, $callback = "_{$action}_{$method}")) {
|
||
call_user_func_array([$this, $callback], $this->request->route());
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 实例方法调用
|
||
* @param string $method 函数名称
|
||
* @param array $arguments 调用参数
|
||
* @return mixed
|
||
* @throws \ReflectionException
|
||
* @throws \think\Exception
|
||
*/
|
||
public function __call($method, $arguments = [])
|
||
{
|
||
if (class_exists($name = "library\\logic\\" . ucfirst(ltrim($method, '_')))) {
|
||
return (new \ReflectionClass($name))->newInstanceArgs($arguments)->init($this);
|
||
}
|
||
throw new \think\Exception('method not exists:' . get_class($this) . '->' . $method);
|
||
}
|
||
|
||
/**
|
||
* 返回失败的操作
|
||
* @param mixed $info 消息内容
|
||
* @param array $data 返回数据
|
||
* @param integer $code 返回代码
|
||
*/
|
||
public function error($info, $data = [], $code = 0)
|
||
{
|
||
$result = ['code' => $code, 'info' => $info, 'data' => $data];
|
||
throw new HttpResponseException(json($result));
|
||
}
|
||
|
||
/**
|
||
* 返回成功的操作
|
||
* @param mixed $info 消息内容
|
||
* @param array $data 返回数据
|
||
* @param integer $code 返回代码
|
||
*/
|
||
public function success($info, $data = [], $code = 1)
|
||
{
|
||
$result = ['code' => $code, 'info' => $info, 'data' => $data];
|
||
if ($this->csrf) Csrf::clearFormToken(Csrf::getToken());
|
||
throw new HttpResponseException(json($result));
|
||
}
|
||
|
||
/**
|
||
* URL重定向
|
||
* @param string $url 跳转链接
|
||
* @param array $vars 跳转参数
|
||
* @param integer $code 跳转代码
|
||
*/
|
||
public function redirect($url, $vars = [], $code = 301)
|
||
{
|
||
throw new HttpResponseException(redirect($url, $vars, $code));
|
||
}
|
||
|
||
/**
|
||
* 返回视图内容
|
||
* @param string $tpl 模板名称
|
||
* @param array $vars 模板变量
|
||
* @param string $node CSRF授权节点
|
||
*/
|
||
public function fetch($tpl = '', $vars = [], $node = null)
|
||
{
|
||
foreach ($this as $name => $value) $vars[$name] = $value;
|
||
if ($this->csrf) {
|
||
Csrf::fetchTemplate($tpl, $vars, $node);
|
||
} else {
|
||
throw new HttpResponseException(view($tpl, $vars));
|
||
}
|
||
}
|
||
|
||
/**
|
||
* 模板变量赋值
|
||
* @param mixed $name 要显示的模板变量
|
||
* @param mixed $value 变量的值
|
||
* @return $this
|
||
*/
|
||
public function assign($name, $value = '')
|
||
{
|
||
if (is_string($name)) {
|
||
$this->$name = $value;
|
||
} elseif (is_array($name)) foreach ($name as $k => $v) {
|
||
if (is_string($k)) $this->$k = $v;
|
||
}
|
||
return $this;
|
||
}
|
||
|
||
/**
|
||
* 数据回调处理机制
|
||
* @param string $name 回调方法名称
|
||
* @param mixed $one 回调引用参数1
|
||
* @param mixed $two 回调引用参数2
|
||
* @return boolean
|
||
*/
|
||
public function callback($name, &$one = [], &$two = [])
|
||
{
|
||
if (is_callable($name)) {
|
||
return call_user_func($name, $this, $one, $two);
|
||
}
|
||
foreach ([$name, "_{$this->request->action()}{$name}"] as $method) {
|
||
if (method_exists($this, $method)) {
|
||
if (false === $this->$method($one, $two)) {
|
||
return false;
|
||
}
|
||
}
|
||
}
|
||
return true;
|
||
}
|
||
|
||
/**
|
||
* 检查表单令牌验证
|
||
* @param boolean $return 是否返回结果
|
||
* @return boolean
|
||
*/
|
||
protected function applyCsrfToken($return = false)
|
||
{
|
||
$this->csrf = true;
|
||
if ($this->request->isPost() && !Csrf::checkFormToken()) {
|
||
if ($return) return false;
|
||
$this->error('表单令牌验证失败,请刷新页面再试!');
|
||
} else {
|
||
return true;
|
||
}
|
||
}
|
||
|
||
}
|