疯狂的狮子li
2023-02-20 d957914c30a70b1b2b9f021945126762fd61470a
fix 修复 LoginHelper 获取 LoginUser 缺失子类扩展数据问题
已修改1个文件
39 ■■■■■ 文件已修改
ruoyi-common/ruoyi-common-satoken/src/main/java/com/ruoyi/common/satoken/utils/LoginHelper.java 39 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
ruoyi-common/ruoyi-common-satoken/src/main/java/com/ruoyi/common/satoken/utils/LoginHelper.java
@@ -3,8 +3,8 @@
import cn.dev33.satoken.context.SaHolder;
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 cn.hutool.json.JSONObject;
import com.ruoyi.common.core.constant.TenantConstants;
import com.ruoyi.common.core.constant.UserConstants;
import com.ruoyi.common.core.domain.model.LoginUser;
@@ -31,7 +31,8 @@
public class LoginHelper {
    public static final String LOGIN_USER_KEY = "loginUser";
    public static final String MENU_PERMISSION = "menuPermission";
    public static final String TENANT_KEY = "tenantId";
    public static final String USER_KEY = "userId";
    /**
     * 登录系统
@@ -50,30 +51,25 @@
     */
    public static void loginByDevice(LoginUser loginUser, DeviceType deviceType) {
        SaHolder.getStorage().set(LOGIN_USER_KEY, loginUser);
        Set<String> menuPermission = loginUser.getMenuPermission();
        loginUser.setMenuPermission(null);
        SaLoginModel model = new SaLoginModel();
        if (ObjectUtil.isNotNull(deviceType)) {
            model.setDevice(deviceType.getDevice());
        }
        StpUtil.login(loginUser.getLoginId(), model.setExtra(LOGIN_USER_KEY, loginUser));
        // 解决菜单权限过度 token 臃肿过长问题
        StpUtil.getTokenSession().set(MENU_PERMISSION, menuPermission);
        StpUtil.login(loginUser.getLoginId(),
            model.setExtra(TENANT_KEY, loginUser.getTenantId())
                .setExtra(USER_KEY, loginUser.getUserId()));
        StpUtil.getTokenSession().set(LOGIN_USER_KEY, loginUser);
    }
    /**
     * 获取用户(多级缓存)
     */
    @SuppressWarnings("unchecked cast")
    public static LoginUser getLoginUser() {
        LoginUser loginUser = (LoginUser) SaHolder.getStorage().get(LOGIN_USER_KEY);
        if (loginUser != null) {
            return loginUser;
        }
        loginUser = ((JSONObject) StpUtil.getExtra(LOGIN_USER_KEY)).toBean(LoginUser.class);
        // 解决菜单权限过度 token 臃肿过长问题
        Set<String> menuPermission = (Set<String>) StpUtil.getTokenSession().get(MENU_PERMISSION);
        loginUser.setMenuPermission(menuPermission);
        loginUser = (LoginUser) StpUtil.getTokenSession().get(LOGIN_USER_KEY);
        SaHolder.getStorage().set(LOGIN_USER_KEY, loginUser);
        return loginUser;
    }
@@ -81,39 +77,34 @@
    /**
     * 获取用户基于token
     */
    @SuppressWarnings("unchecked cast")
    public static LoginUser getLoginUser(String token) {
        LoginUser loginUser = ((JSONObject) StpUtil.getExtra(token, LOGIN_USER_KEY)).toBean(LoginUser.class);
        // 解决菜单权限过度 token 臃肿过长问题
        Set<String> menuPermission = (Set<String>) StpUtil.getTokenSessionByToken(token).get(MENU_PERMISSION);
        loginUser.setMenuPermission(menuPermission);
        return loginUser;
        return (LoginUser) StpUtil.getTokenSessionByToken(token).get(LOGIN_USER_KEY);
    }
    /**
     * 获取用户id
     */
    public static Long getUserId() {
        LoginUser loginUser;
        Long userId;
        try {
            loginUser = getLoginUser();
            userId = Convert.toLong(StpUtil.getExtra(USER_KEY));
        } catch (Exception e) {
            return null;
        }
        return loginUser.getUserId();
        return userId;
    }
    /**
     * 获取租户ID
     */
    public static String getTenantId() {
        LoginUser loginUser;
        String tenantId;
        try {
            loginUser = getLoginUser();
            tenantId = (String) StpUtil.getExtra(TENANT_KEY);
        } catch (Exception e) {
            return null;
        }
        return loginUser.getTenantId();
        return tenantId;
    }
    /**