SysLoginController.java 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package com.ruoyi.web.controller.system;
  2. import java.util.List;
  3. import java.util.Set;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.web.bind.annotation.GetMapping;
  6. import org.springframework.web.bind.annotation.PostMapping;
  7. import org.springframework.web.bind.annotation.RequestBody;
  8. import org.springframework.web.bind.annotation.RestController;
  9. import com.ruoyi.common.constant.Constants;
  10. import com.ruoyi.common.core.domain.AjaxResult;
  11. import com.ruoyi.common.core.domain.entity.SysMenu;
  12. import com.ruoyi.common.core.domain.entity.SysUser;
  13. import com.ruoyi.common.core.domain.model.LoginBody;
  14. import com.ruoyi.common.core.domain.model.LoginUser;
  15. import com.ruoyi.common.utils.SecurityUtils;
  16. import com.ruoyi.framework.web.service.SysLoginService;
  17. import com.ruoyi.framework.web.service.SysPermissionService;
  18. import com.ruoyi.framework.web.service.TokenService;
  19. import com.ruoyi.system.service.ISysMenuService;
  20. /**
  21. * 登录验证
  22. *
  23. * @author ruoyi
  24. */
  25. @RestController
  26. public class SysLoginController
  27. {
  28. @Autowired
  29. private SysLoginService loginService;
  30. @Autowired
  31. private ISysMenuService menuService;
  32. @Autowired
  33. private SysPermissionService permissionService;
  34. @Autowired
  35. private TokenService tokenService;
  36. /**
  37. * 登录方法
  38. *
  39. * @param loginBody 登录信息
  40. * @return 结果
  41. */
  42. @PostMapping("/login")
  43. public AjaxResult login(@RequestBody LoginBody loginBody)
  44. {
  45. AjaxResult ajax = AjaxResult.success();
  46. // 生成令牌
  47. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  48. loginBody.getUuid());
  49. ajax.put(Constants.TOKEN, token);
  50. return ajax;
  51. }
  52. /**
  53. * 无验证码登录方法
  54. *
  55. * @param loginBody 登录信息
  56. * @return 结果
  57. */
  58. @PostMapping("/loginNoCaptcha")
  59. public AjaxResult loginNoCaptcha(@RequestBody LoginBody loginBody)
  60. {
  61. AjaxResult ajax = AjaxResult.success();
  62. // 生成令牌
  63. String token = loginService.loginNoCaptcha(loginBody.getUsername(), loginBody.getPassword());
  64. ajax.put(Constants.TOKEN, token);
  65. return ajax;
  66. }
  67. /**
  68. * 获取用户信息
  69. *
  70. * @return 用户信息
  71. */
  72. @GetMapping("getInfo")
  73. public AjaxResult getInfo()
  74. {
  75. LoginUser loginUser = SecurityUtils.getLoginUser();
  76. SysUser user = loginUser.getUser();
  77. // 角色集合
  78. Set<String> roles = permissionService.getRolePermission(user);
  79. // 权限集合
  80. Set<String> permissions = permissionService.getMenuPermission(user);
  81. if (!loginUser.getPermissions().equals(permissions))
  82. {
  83. loginUser.setPermissions(permissions);
  84. tokenService.refreshToken(loginUser);
  85. }
  86. AjaxResult ajax = AjaxResult.success();
  87. ajax.put("user", user);
  88. ajax.put("roles", roles);
  89. ajax.put("permissions", permissions);
  90. return ajax;
  91. }
  92. /**
  93. * 获取路由信息
  94. *
  95. * @return 路由信息
  96. */
  97. @GetMapping("getRouters")
  98. public AjaxResult getRouters()
  99. {
  100. Long userId = SecurityUtils.getUserId();
  101. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  102. return AjaxResult.success(menuService.buildMenus(menus));
  103. }
  104. }