app = $app; $this->request = $this->app->request; // 控制器初始化 $this->initialize(); } // 初始化 protected function initialize() { } //系统设置项 public function Setting($key = false, $def = false, $emptyReplace = false) { if ($this->SettingConfig === false) { $this->SettingConfig = SettingModel::Config(); } if ($key) { if (isset($this->SettingConfig[$key])) { if ($emptyReplace && empty($this->SettingConfig[$key])) { return $def; } return $this->SettingConfig[$key]; } return $def; } return $this->SettingConfig; } /** * @description :用户信息获取 * @param false $must 是否强制验证,true则强制验证程序退出 * @return TokenModel|array|bool|mixed|Model|void * @throws DataNotFoundException * @throws DbException * @throws ModelNotFoundException */ public function getUser(bool $must = false) { $id = $this->request->header("Userid"); $token = $this->request->header("Token", ''); if ($id && $token) { if ($this->user_temp) return $this->user_temp; $user = TokenModel::where("user_id", $id)->where('token', $token)->field("user_id,token,create_time")->cache('user.' . $id, 300)->find(); if ($user) { if ((time() - $user['create_time']) > (864000)) { //token定时15天清理一次,10-15天内如果使用了则重新计算时间 $user->create_time = time(); $user->save(); } $this->user_temp = $user; return $user; } } if ($must) { $this->error("请登录后操作")->send(); exit(); } return false; } //admin认证 public function getAdmin() { $user = $this->getUser(true); $info = UserModel::where('id', $user['user_id'])->where("manager", 1)->find(); if ($info) { return $info; } $this->error('not permission')->send(); exit(); } public function success($msg, $data = []): \think\response\Json { if (is_array($msg)) { return json(['msg' => "", "code" => 1, "data" => $msg]); } return json(['msg' => $msg, "code" => 1, "data" => $data]); } public function error($msg, $data = []): \think\response\Json { if (is_array($msg)) { return json(['msg' => "", "code" => 0, "data" => $msg]); } return json(['msg' => $msg, "code" => 0, "data" => $data]); } }