SysLoginController.java 2.8 KB

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