SysLoginController.java 4.7 KB

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