find(); if (empty($info)) return self::setErrorInfo("登录账号不存在"); if ($info['password'] != md5(md5($pwd))) return self::setErrorInfo("密码不正确!"); if ($info['status'] != 1) return self::setErrorInfo("账号已被冻结!"); self::setLoginInfo($info); return true; } /** * 设置登录信息 * @param $info * @return bool */ public static function setLoginInfo($info) { unset($info->password);//去除密码字段 $info->role_auth = AdminRole::getAuth($info['role_id'] ?? 0);//提前缓存auth字段避免频繁查询 Session::set(Data::SESSION_KEY_ADMIN_ID, $info['id']); Session::set(Data::SESSION_KEY_ADMIN_INFO, $info->toArray()); event("AdminLog", [$info->toArray(), "admin", "login", "login"]); return true; } /** * 退出登录 */ public static function clearLoginInfo() { Session::delete(Data::SESSION_KEY_ADMIN_ID); Session::delete(Data::SESSION_KEY_ADMIN_INFO); Session::clear(); return true; } /** * 列表 * @param array $where * @return array * @throws DataNotFoundException * @throws DbException * @throws ModelNotFoundException */ public static function systemPage(array $where): array { $model = new self; if ($where['username'] != '') $model = $model->where("username|id|nickname", "like", "%$where[username]%"); if ($where['start_time'] != '') $model = $model->where("create_time", ">", strtotime($where['start_time'] . " 00:00:00")); if ($where['end_time'] != '') $model = $model->where("create_time", "<", strtotime($where['end_time'] . " 23:59:59")); if ($where['tel'] != '') $model = $model->where("tel|mail", "like", "%$where[tel]%"); if ($where['status'] != '') $model = $model->where("status", $where['status']); if ($where['role_id'] != '') $model = $model->where("role_id", $where['role_id']); $count = self::counts($model); if ($where['page'] && $where['limit']) $model = $model->page((int)$where['page'], (int)$where['limit']); $data = $model->select()->each(function ($item) { unset($item['password']); // 用户信息 $info = self::getAdminInfoById((int)$item['create_user']); $item['create_user'] = $info ? $info['nickname'] : $item['create_user']; $item['role_id'] = AdminRole::getAuthNameById((int)$item['role_id']); }); $data = $data ? $data->toArray() : []; return compact("data", "count"); } /** * 获取账号信息 * @param int $id * @param string $field * @return array * @throws DataNotFoundException * @throws DbException * @throws ModelNotFoundException */ public static function getAdminInfoById(int $id, string $field = '*'): array { $model = new self; $model = $model->where("id", $id); $model = $model->field($field); $info = $model->find(); unset($info->password); return $info ? $info->toArray() : []; } /** * 人员列表 * @return array * @throws DataNotFoundException * @throws DbException * @throws ModelNotFoundException */ public static function lst() { $model = new self; $model = $model->where("status", 1); $model = $model->field("id,realname"); $data = $model->select(); return $data ? $data->toArray() : []; } }