package com.dl.common.helper; import cn.dev33.satoken.context.SaHolder; import cn.dev33.satoken.context.model.SaStorage; import cn.dev33.satoken.stp.SaLoginModel; import cn.dev33.satoken.stp.StpUtil; import cn.hutool.core.convert.Convert; import cn.hutool.core.util.ObjectUtil; import com.dl.common.constant.UserConstants; import com.dl.common.core.domain.model.LoginUser; import com.dl.common.enums.DeviceType; import com.dl.common.enums.UserType; import lombok.AccessLevel; import lombok.NoArgsConstructor; import java.util.Objects; /** * 登录鉴权助手 *

* user_type 为 用户类型 同一个用户表 可以有多种用户类型 例如 pc,app * deivce 为 设备类型 同一个用户类型 可以有 多种设备类型 例如 web,ios * 可以组成 用户类型与设备类型多对多的 权限灵活控制 *

* 多用户体系 针对 多种用户类型 但权限控制不一致 * 可以组成 多用户类型表与多设备类型 分别控制权限 * * @author Lion Li */ @NoArgsConstructor(access = AccessLevel.PRIVATE) public class LoginHelper { public static final String LOGIN_USER_KEY = "loginUser"; public static final String USER_KEY = "userId"; /** * 登录系统 * * @param loginUser 登录用户信息 */ public static void login(LoginUser loginUser) { loginByDevice(loginUser, null); } /** * 登录系统 基于 设备类型 * 针对相同用户体系不同设备 * * @param loginUser 登录用户信息 */ public static void loginByDevice(LoginUser loginUser, DeviceType deviceType) { SaStorage storage = SaHolder.getStorage(); storage.set(LOGIN_USER_KEY, loginUser); storage.set(USER_KEY, loginUser.getUserId()); SaLoginModel model = new SaLoginModel(); if (ObjectUtil.isNotNull(deviceType)) { model.setDevice(deviceType.getDevice()); } StpUtil.login(loginUser.getLoginId(), model.setExtra(USER_KEY, loginUser.getUserId())); StpUtil.getTokenSession().set(LOGIN_USER_KEY, loginUser); } /** * 获取用户(多级缓存) */ public static LoginUser getLoginUser() { LoginUser loginUser = (LoginUser) SaHolder.getStorage().get(LOGIN_USER_KEY); if (loginUser != null) { return loginUser; } loginUser = (LoginUser) StpUtil.getTokenSession().get(LOGIN_USER_KEY); SaHolder.getStorage().set(LOGIN_USER_KEY, loginUser); return loginUser; } /** * 获取用户基于token */ public static LoginUser getLoginUser(String token) { return (LoginUser) StpUtil.getTokenSessionByToken(token).get(LOGIN_USER_KEY); } /** * 获取用户id */ public static String getUserId() { String userId; try { userId = (String) SaHolder.getStorage().get(USER_KEY); if (ObjectUtil.isNull(userId)) { userId = (String) StpUtil.getExtra(USER_KEY); SaHolder.getStorage().set(USER_KEY, userId); } } catch (Exception e) { return null; } return userId; } /** * 获取部门ID */ public static Long getDeptId() { return getLoginUser().getDeptId(); } /** * 获取用户账户 */ public static String getUsername() { return getLoginUser().getUsername(); } /** * 获取用户昵称 */ public static String getNickName() { return getLoginUser().getNickName(); } /** * 获取用户类型 */ public static UserType getUserType() { String loginId = StpUtil.getLoginIdAsString(); return UserType.getUserType(loginId); } /** * 是否为管理员 * * @param userId 用户ID * @return 结果 */ public static boolean isAdmin(String userId) { return UserConstants.ADMIN_ID.equals(userId); } public static boolean isAdmin() { return isAdmin(getUserId()); } }