SysLoginController.java 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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.LoginByTelephoneBody;
  8. import com.ruoyi.common.utils.SecurityUtils;
  9. import com.ruoyi.framework.web.service.SysLoginService;
  10. import com.ruoyi.framework.web.service.SysPermissionService;
  11. import com.ruoyi.system.service.ISysMenuService;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.web.bind.annotation.GetMapping;
  14. import org.springframework.web.bind.annotation.PostMapping;
  15. import org.springframework.web.bind.annotation.RequestBody;
  16. import org.springframework.web.bind.annotation.RestController;
  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. /**
  33. * 登录方法
  34. *
  35. * @param loginBody 登录信息
  36. * @return 结果
  37. */
  38. @PostMapping("/login")
  39. public AjaxResult login(@RequestBody LoginBody loginBody) {
  40. AjaxResult ajax = AjaxResult.success();
  41. // 生成令牌
  42. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  43. loginBody.getUuid(), false);
  44. ajax.put(Constants.TOKEN, token);
  45. return ajax;
  46. }
  47. /**
  48. * 登录方法
  49. *
  50. * @param loginBody 登录信息
  51. * @return 结果
  52. */
  53. @PostMapping("/loginCommunity")
  54. public AjaxResult loginCommunity(@RequestBody LoginBody loginBody) {
  55. AjaxResult ajax = AjaxResult.success();
  56. // 生成令牌
  57. String token = loginService.login(loginBody.getUsername(), loginBody.getPassword(), loginBody.getCode(),
  58. loginBody.getUuid(), true);
  59. ajax.put(Constants.TOKEN, token);
  60. return ajax;
  61. }
  62. /**
  63. * 获取用户信息
  64. *
  65. * @return 用户信息
  66. */
  67. @GetMapping("getInfo")
  68. public AjaxResult getInfo() {
  69. SysUser user = SecurityUtils.getLoginUser().getUser();
  70. // 角色集合
  71. Set<String> roles = permissionService.getRolePermission(user);
  72. // 权限集合
  73. Set<String> permissions = permissionService.getMenuPermission(user);
  74. AjaxResult ajax = AjaxResult.success();
  75. ajax.put("user", user);
  76. ajax.put("roles", roles);
  77. ajax.put("permissions", permissions);
  78. return ajax;
  79. }
  80. /**
  81. * 获取路由信息
  82. *
  83. * @return 路由信息
  84. */
  85. @GetMapping("getRouters")
  86. public AjaxResult getRouters() {
  87. Long userId = SecurityUtils.getUserId();
  88. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  89. return AjaxResult.success(menuService.buildMenus(menus));
  90. }
  91. @PostMapping("/phoneLogin")
  92. public AjaxResult phoneLogin(@RequestBody LoginByTelephoneBody loginBody){
  93. AjaxResult ajax = AjaxResult.success();
  94. // 生成令牌
  95. String token = loginService.loginByTelephone(loginBody.getUsername(), loginBody.getCode(),
  96. loginBody.getUuid());
  97. ajax.put(Constants.TOKEN, token);
  98. return ajax;
  99. }
  100. }