SysLoginController.java 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package com.ruoyi.web.controller.system;
  2. import java.util.List;
  3. import java.util.Set;
  4. import com.ruoyi.web.service.CommService;
  5. import io.swagger.annotations.Api;
  6. import io.swagger.annotations.ApiOperation;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.web.bind.annotation.GetMapping;
  9. import org.springframework.web.bind.annotation.PostMapping;
  10. import org.springframework.web.bind.annotation.RequestBody;
  11. import org.springframework.web.bind.annotation.RestController;
  12. import com.ruoyi.common.constant.Constants;
  13. import com.ruoyi.common.core.domain.AjaxResult;
  14. import com.ruoyi.common.core.domain.entity.SysMenu;
  15. import com.ruoyi.common.core.domain.entity.SysUser;
  16. import com.ruoyi.common.core.domain.model.LoginBody;
  17. import com.ruoyi.common.core.domain.model.LoginUser;
  18. import com.ruoyi.common.utils.SecurityUtils;
  19. import com.ruoyi.web.service.SysLoginService;
  20. import com.ruoyi.framework.web.service.SysPermissionService;
  21. import com.ruoyi.framework.web.service.TokenService;
  22. import com.ruoyi.system.service.ISysMenuService;
  23. /**
  24. * 登录验证
  25. *
  26. * @author ruoyi
  27. */
  28. @Api(tags = "系统-登陆")
  29. @RestController
  30. public class SysLoginController
  31. {
  32. @Autowired
  33. private SysLoginService loginService;
  34. @Autowired
  35. private ISysMenuService menuService;
  36. @Autowired
  37. private SysPermissionService permissionService;
  38. @Autowired
  39. private TokenService tokenService;
  40. @Autowired
  41. private CommService commService;
  42. /**
  43. * 登录方法
  44. *
  45. * @param loginBody 登录信息
  46. * @return 结果
  47. */
  48. @PostMapping("login")
  49. @ApiOperation("登陆")
  50. public AjaxResult login(@RequestBody LoginBody loginBody)
  51. {
  52. AjaxResult ajax = AjaxResult.success();
  53. // 生成令牌
  54. String token = loginService.login(loginBody.getMobile(), loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(), loginBody.getUuid());
  55. ajax.put(Constants.TOKEN, token);
  56. return ajax;
  57. }
  58. /**
  59. * 获取用户信息
  60. *
  61. * @return 用户信息
  62. */
  63. @GetMapping("getInfo")
  64. @ApiOperation("个人信息")
  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("card", loginUser.getCard());
  81. ajax.put("roles", roles);
  82. ajax.put("permissions", permissions);
  83. ajax.put("isDefaultModifyPwd", commService.initPasswordIsModify(user.getPwdUpdateDate()));
  84. ajax.put("isPasswordExpired", commService.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. }