LoginHelper.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package com.ruoyi.common.helper;
  2. import cn.dev33.satoken.context.SaHolder;
  3. import cn.dev33.satoken.context.model.SaStorage;
  4. import cn.dev33.satoken.stp.SaLoginModel;
  5. import cn.dev33.satoken.stp.StpUtil;
  6. import cn.hutool.core.convert.Convert;
  7. import cn.hutool.core.util.ObjectUtil;
  8. import com.ruoyi.common.constant.UserConstants;
  9. import com.ruoyi.common.core.domain.model.LoginUser;
  10. import com.ruoyi.common.enums.DeviceType;
  11. import com.ruoyi.common.enums.UserType;
  12. import lombok.AccessLevel;
  13. import lombok.NoArgsConstructor;
  14. /**
  15. * 登录鉴权助手
  16. * <p>
  17. * user_type 为 用户类型 同一个用户表 可以有多种用户类型 例如 pc,app
  18. * deivce 为 设备类型 同一个用户类型 可以有 多种设备类型 例如 web,ios
  19. * 可以组成 用户类型与设备类型多对多的 权限灵活控制
  20. * <p>
  21. * 多用户体系 针对 多种用户类型 但权限控制不一致
  22. * 可以组成 多用户类型表与多设备类型 分别控制权限
  23. *
  24. * @author Lion Li
  25. */
  26. @NoArgsConstructor(access = AccessLevel.PRIVATE)
  27. public class LoginHelper {
  28. public static final String LOGIN_USER_KEY = "loginUser";
  29. public static final String USER_KEY = "userId";
  30. /**
  31. * 登录系统
  32. *
  33. * @param loginUser 登录用户信息
  34. */
  35. public static void login(LoginUser loginUser) {
  36. loginByDevice(loginUser, null);
  37. }
  38. /**
  39. * 登录系统 基于 设备类型
  40. * 针对相同用户体系不同设备
  41. *
  42. * @param loginUser 登录用户信息
  43. */
  44. public static void loginByDevice(LoginUser loginUser, DeviceType deviceType) {
  45. SaStorage storage = SaHolder.getStorage();
  46. storage.set(LOGIN_USER_KEY, loginUser);
  47. storage.set(USER_KEY, loginUser.getUserId());
  48. SaLoginModel model = new SaLoginModel();
  49. if (ObjectUtil.isNotNull(deviceType)) {
  50. model.setDevice(deviceType.getDevice());
  51. }
  52. StpUtil.login(loginUser.getLoginId(), model.setExtra(USER_KEY, loginUser.getUserId()));
  53. StpUtil.getTokenSession().set(LOGIN_USER_KEY, loginUser);
  54. }
  55. /**
  56. * 获取用户(多级缓存)
  57. */
  58. public static LoginUser getLoginUser() {
  59. LoginUser loginUser = (LoginUser) SaHolder.getStorage().get(LOGIN_USER_KEY);
  60. if (loginUser != null) {
  61. return loginUser;
  62. }
  63. loginUser = (LoginUser) StpUtil.getTokenSession().get(LOGIN_USER_KEY);
  64. SaHolder.getStorage().set(LOGIN_USER_KEY, loginUser);
  65. return loginUser;
  66. }
  67. /**
  68. * 获取用户基于token
  69. */
  70. public static LoginUser getLoginUser(String token) {
  71. return (LoginUser) StpUtil.getTokenSessionByToken(token).get(LOGIN_USER_KEY);
  72. }
  73. /**
  74. * 获取用户id
  75. */
  76. public static Long getUserId() {
  77. Long userId;
  78. try {
  79. userId = Convert.toLong(SaHolder.getStorage().get(USER_KEY));
  80. if (ObjectUtil.isNull(userId)) {
  81. userId = Convert.toLong(StpUtil.getExtra(USER_KEY));
  82. SaHolder.getStorage().set(USER_KEY, userId);
  83. }
  84. } catch (Exception e) {
  85. return null;
  86. }
  87. return userId;
  88. }
  89. /**
  90. * 获取部门ID
  91. */
  92. public static Long getDeptId() {
  93. return getLoginUser().getDeptId();
  94. }
  95. /**
  96. * 获取用户账户
  97. */
  98. public static String getUsername() {
  99. return getLoginUser().getUsername();
  100. }
  101. /**
  102. * 获取用户类型
  103. */
  104. public static UserType getUserType() {
  105. String loginId = StpUtil.getLoginIdAsString();
  106. return UserType.getUserType(loginId);
  107. }
  108. /**
  109. * 是否为管理员
  110. *
  111. * @param userId 用户ID
  112. * @return 结果
  113. */
  114. public static boolean isAdmin(Long userId) {
  115. return UserConstants.ADMIN_ID.equals(userId);
  116. }
  117. public static boolean isAdmin() {
  118. return isAdmin(getUserId());
  119. }
  120. }