SysLoginController.java 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. package com.ruoyi.web.controller.system;
  2. import java.util.Date;
  3. import java.util.List;
  4. import java.util.Set;
  5. import org.springframework.beans.factory.annotation.Autowired;
  6. import org.springframework.web.bind.annotation.GetMapping;
  7. import org.springframework.web.bind.annotation.PostMapping;
  8. import org.springframework.web.bind.annotation.RequestBody;
  9. import org.springframework.web.bind.annotation.RestController;
  10. import com.ruoyi.common.constant.Constants;
  11. import com.ruoyi.common.core.domain.AjaxResult;
  12. import com.ruoyi.common.core.domain.entity.SysMenu;
  13. import com.ruoyi.common.core.domain.entity.SysUser;
  14. import com.ruoyi.common.core.domain.model.LoginBody;
  15. import com.ruoyi.common.core.domain.model.LoginUser;
  16. import com.ruoyi.common.core.text.Convert;
  17. import com.ruoyi.common.utils.DateUtils;
  18. import com.ruoyi.common.utils.SecurityUtils;
  19. import com.ruoyi.common.utils.StringUtils;
  20. import com.ruoyi.framework.web.service.SysLoginService;
  21. import com.ruoyi.framework.web.service.SysPermissionService;
  22. import com.ruoyi.framework.web.service.TokenService;
  23. import com.ruoyi.system.service.ISysConfigService;
  24. import com.ruoyi.system.service.ISysMenuService;
  25. /**
  26. * 登录验证
  27. *
  28. * @author ruoyi
  29. */
  30. @RestController
  31. public class SysLoginController
  32. {
  33. @Autowired
  34. private SysLoginService loginService;
  35. @Autowired
  36. private ISysMenuService menuService;
  37. @Autowired
  38. private SysPermissionService permissionService;
  39. @Autowired
  40. private TokenService tokenService;
  41. @Autowired
  42. private ISysConfigService configService;
  43. /**
  44. * 登录方法
  45. *
  46. * @param loginBody 登录信息
  47. * @return 结果
  48. */
  49. @PostMapping("/login")
  50. public AjaxResult login(@RequestBody LoginBody loginBody)
  51. {
  52. AjaxResult ajax = AjaxResult.success();
  53. // 生成令牌
  54. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  55. loginBody.getUuid());
  56. ajax.put(Constants.TOKEN, token);
  57. return ajax;
  58. }
  59. /**
  60. * 获取用户信息
  61. *
  62. * @return 用户信息
  63. */
  64. @GetMapping("getInfo")
  65. public AjaxResult getInfo()
  66. {
  67. LoginUser loginUser = SecurityUtils.getLoginUser();
  68. SysUser user = loginUser.getUser();
  69. // 角色集合
  70. Set<String> roles = permissionService.getRolePermission(user);
  71. // 权限集合
  72. Set<String> permissions = permissionService.getMenuPermission(user);
  73. if (!loginUser.getPermissions().equals(permissions))
  74. {
  75. loginUser.setPermissions(permissions);
  76. tokenService.refreshToken(loginUser);
  77. }
  78. AjaxResult ajax = AjaxResult.success();
  79. ajax.put("user", user);
  80. ajax.put("roles", roles);
  81. ajax.put("permissions", permissions);
  82. ajax.put("isDefaultModifyPwd", initPasswordIsModify(user.getPwdUpdateDate()));
  83. ajax.put("isPasswordExpired", passwordIsExpiration(user.getPwdUpdateDate()));
  84. return ajax;
  85. }
  86. /**
  87. * 获取路由信息
  88. *
  89. * @return 路由信息
  90. */
  91. @GetMapping("getRouters")
  92. public AjaxResult getRouters()
  93. {
  94. Long userId = SecurityUtils.getUserId();
  95. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  96. return AjaxResult.success(menuService.buildMenus(menus));
  97. }
  98. // 检查初始密码是否提醒修改
  99. public boolean initPasswordIsModify(Date pwdUpdateDate)
  100. {
  101. Integer initPasswordModify = Convert.toInt(configService.selectConfigByKey("sys.account.initPasswordModify"));
  102. return initPasswordModify != null && initPasswordModify == 1 && pwdUpdateDate == null;
  103. }
  104. // 检查密码是否过期
  105. public boolean passwordIsExpiration(Date pwdUpdateDate)
  106. {
  107. Integer passwordValidateDays = Convert.toInt(configService.selectConfigByKey("sys.account.passwordValidateDays"));
  108. if (passwordValidateDays != null && passwordValidateDays > 0)
  109. {
  110. if (StringUtils.isNull(pwdUpdateDate))
  111. {
  112. // 如果从未修改过初始密码,直接提醒过期
  113. return true;
  114. }
  115. Date nowDate = DateUtils.getNowDate();
  116. return DateUtils.differentDaysByMillisecond(nowDate, pwdUpdateDate) > passwordValidateDays;
  117. }
  118. return false;
  119. }
  120. }