SysLoginController.java 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. package com.jjt.web.controller.system;
  2. import com.jjt.common.constant.Constants;
  3. import com.jjt.common.core.domain.AjaxResult;
  4. import com.jjt.common.core.domain.entity.SysMenu;
  5. import com.jjt.common.core.domain.entity.SysUser;
  6. import com.jjt.common.core.domain.model.LoginBody;
  7. import com.jjt.common.utils.SecurityUtils;
  8. import com.jjt.framework.web.service.SysLoginService;
  9. import com.jjt.framework.web.service.SysPermissionService;
  10. import com.jjt.system.service.ISysMenuService;
  11. import org.springframework.web.bind.annotation.*;
  12. import javax.annotation.Resource;
  13. import java.util.List;
  14. import java.util.Set;
  15. /**
  16. * 登录验证
  17. *
  18. * @author jjt
  19. */
  20. @RestController
  21. public class SysLoginController {
  22. @Resource
  23. private SysLoginService loginService;
  24. @Resource
  25. private ISysMenuService menuService;
  26. @Resource
  27. private SysPermissionService permissionService;
  28. /**
  29. * 登录方法
  30. *
  31. * @param loginBody 登录信息
  32. * @return 结果
  33. */
  34. @PostMapping("/login")
  35. public AjaxResult login(@RequestBody LoginBody loginBody) {
  36. AjaxResult ajax = AjaxResult.success();
  37. // 生成令牌
  38. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  39. loginBody.getUuid());
  40. ajax.put(Constants.TOKEN, token);
  41. return ajax;
  42. }
  43. /**
  44. * 模拟登录
  45. *
  46. * @return 结果
  47. */
  48. @PostMapping("/api/loginSso")
  49. public AjaxResult loginSso() {
  50. LoginBody loginBody = new LoginBody();
  51. loginBody.setUsername("admin");
  52. loginBody.setPassword("admin123");
  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. @PostMapping("/api/userInfo")
  66. public AjaxResult getInfo() {
  67. SysUser user = SecurityUtils.getLoginUser().getUser();
  68. // 角色集合
  69. Set<String> roles = permissionService.getRolePermission(user);
  70. // 权限集合
  71. Set<String> permissions = permissionService.getMenuPermission(user);
  72. AjaxResult ajax = AjaxResult.success();
  73. ajax.put("user", user);
  74. ajax.put("roles", roles);
  75. ajax.put("permissions", permissions);
  76. return ajax;
  77. }
  78. /**
  79. * 获取路由信息
  80. *
  81. * @return 路由信息
  82. */
  83. @PostMapping("/api/userRouters")
  84. public AjaxResult getRouters() {
  85. Long userId = SecurityUtils.getUserId();
  86. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  87. return AjaxResult.success(menuService.buildMenus(menus));
  88. }
  89. }