123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- <?php
- namespace app\store\controller;
- use app\store\service\Auth;
- use app\store\service\Menus;
- use app\store\model\Setting;
- use app\common\exception\BaseException;
- use think\Request;
- use think\Session;
- /**
- * 商户后台控制器基类
- * Class BaseController
- * @package app\store\controller
- */
- class Controller extends \think\Controller
- {
- /** @var array $store 商家登录信息 */
- protected $store;
- /** @var string $route 当前控制器名称 */
- protected $controller = '';
- /** @var string $route 当前方法名称 */
- protected $action = '';
- /** @var string $route 当前路由uri */
- protected $routeUri = '';
- /** @var string $route 当前路由:分组名称 */
- protected $group = '';
- /** @var array $allowAllAction 登录验证白名单 */
- protected $allowAllAction = [
- // 登录页面
- 'passport/login',
- ];
- /* @var array $notLayoutAction 无需全局layout */
- protected $notLayoutAction = [
- // 登录页面
- 'passport/login',
- ];
- /**
- * 后台初始化
- * @throws BaseException
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\ModelNotFoundException
- * @throws \think\exception\DbException
- */
- public function _initialize()
- {
- // 商家登录信息
- $this->store = Session::get('yoshop_store');
- // 当前路由信息
- $this->getRouteinfo();
- // 验证登录状态
- $this->checkLogin();
- // 验证当前页面权限
- $this->checkPrivilege();
- // 全局layout
- $this->layout();
- }
- /**
- * 验证当前页面权限
- * @throws BaseException
- * @throws \think\db\exception\DataNotFoundException
- * @throws \think\db\exception\ModelNotFoundException
- * @throws \think\exception\DbException
- */
- private function checkPrivilege()
- {
- if ($this->routeUri === 'index/index') {
- return true;
- }
- if (!Auth::getInstance()->checkPrivilege($this->routeUri)) {
- throw new BaseException(['msg' => '很抱歉,没有访问权限']);
- }
- return true;
- }
- /**
- * 全局layout模板输出
- * @throws \think\exception\DbException
- * @throws \Exception
- */
- private function layout()
- {
- // 验证当前请求是否在白名单
- if (!in_array($this->routeUri, $this->notLayoutAction)) {
- // 输出到view
- $this->assign([
- 'base_url' => base_url(), // 当前域名
- 'store_url' => url('/store'), // 后台模块url
- 'group' => $this->group, // 当前控制器分组
- 'menus' => $this->menus(), // 后台菜单
- 'store' => $this->store, // 商家登录信息
- 'setting' => Setting::getAll() ?: null, // 当前商城设置
- 'request' => Request::instance(), // Request对象
- 'version' => get_version(), // 系统版本号
- ]);
- }
- }
- /**
- * 解析当前路由参数 (分组名称、控制器名称、方法名)
- */
- protected function getRouteinfo()
- {
- // 控制器名称
- $this->controller = toUnderScore($this->request->controller());
- // 方法名称
- $this->action = $this->request->action();
- // 控制器分组 (用于定义所属模块)
- $groupstr = strstr($this->controller, '.', true);
- $this->group = $groupstr !== false ? $groupstr : $this->controller;
- // 当前uri
- $this->routeUri = $this->controller . '/' . $this->action;
- }
- /**
- * 后台菜单配置
- * @return mixed
- * @throws \think\exception\DbException
- */
- protected function menus()
- {
- static $menus = [];
- if (empty($menus)) {
- $menus = Menus::getInstance()->getMenus($this->routeUri, $this->group);
- }
- return $menus;
- }
- /**
- * 验证登录状态
- * @return bool
- */
- private function checkLogin()
- {
- // 验证当前请求是否在白名单
- if (in_array($this->routeUri, $this->allowAllAction)) {
- return true;
- }
- // 验证登录状态
- if (empty($this->store)
- || (int)$this->store['is_login'] !== 1
- || !isset($this->store['wxapp'])
- || empty($this->store['wxapp'])
- ) {
- $this->redirect('passport/login');
- return false;
- }
- return true;
- }
- /**
- * 获取当前wxapp_id
- */
- protected function getWxappId()
- {
- return $this->store['wxapp']['wxapp_id'];
- }
- /**
- * 返回封装后的 API 数据到客户端
- * @param int $code
- * @param string $msg
- * @param string $url
- * @param array $data
- * @return array
- */
- protected function renderJson($code = 1, $msg = '', $url = '', $data = [])
- {
- return compact('code', 'msg', 'url', 'data');
- }
- /**
- * 返回操作成功json
- * @param string $msg
- * @param string $url
- * @param array $data
- * @return array
- */
- protected function renderSuccess($msg = 'success', $url = '', $data = [])
- {
- return $this->renderJson(1, $msg, $url, $data);
- }
- /**
- * 返回操作失败json
- * @param string $msg
- * @param string $url
- * @param array $data
- * @return array|bool
- */
- protected function renderError($msg = 'error', $url = '', $data = [])
- {
- if ($this->request->isAjax()) {
- return $this->renderJson(0, $msg, $url, $data);
- }
- $this->error($msg);
- return false;
- }
- /**
- * 获取post数据 (数组)
- * @param $key
- * @return mixed
- */
- protected function postData($key = null)
- {
- return $this->request->post(is_null($key) ? '' : $key . '/a');
- }
- /**
- * 获取post数据 (数组)
- * @param $key
- * @return mixed
- */
- protected function getData($key = null)
- {
- return $this->request->get(is_null($key) ? '' : $key);
- }
- }
|