SysLoginController.java 2.6 KB

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