SysLoginController.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package com.ruoyi.web.controller.system;
  2. import com.ruoyi.common.annotation.Anonymous;
  3. import com.ruoyi.common.constant.Constants;
  4. import com.ruoyi.common.core.domain.R;
  5. import com.ruoyi.common.core.domain.entity.SysMenu;
  6. import com.ruoyi.common.core.domain.entity.SysUser;
  7. import com.ruoyi.common.core.domain.model.LoginBody;
  8. import com.ruoyi.common.core.domain.model.SmsLoginBody;
  9. import com.ruoyi.common.helper.LoginHelper;
  10. import com.ruoyi.system.domain.vo.RouterVo;
  11. import com.ruoyi.system.service.ISysMenuService;
  12. import com.ruoyi.system.service.ISysUserService;
  13. import com.ruoyi.system.service.SysLoginService;
  14. import com.ruoyi.system.service.SysPermissionService;
  15. import lombok.RequiredArgsConstructor;
  16. import org.springframework.validation.annotation.Validated;
  17. import org.springframework.web.bind.annotation.GetMapping;
  18. import org.springframework.web.bind.annotation.PostMapping;
  19. import org.springframework.web.bind.annotation.RequestBody;
  20. import org.springframework.web.bind.annotation.RestController;
  21. import javax.validation.constraints.NotBlank;
  22. import java.util.HashMap;
  23. import java.util.List;
  24. import java.util.Map;
  25. import java.util.Set;
  26. /**
  27. * 登录验证
  28. *
  29. * @author Lion Li
  30. */
  31. @Validated
  32. @RequiredArgsConstructor
  33. @RestController
  34. public class SysLoginController {
  35. private final SysLoginService loginService;
  36. private final ISysMenuService menuService;
  37. private final ISysUserService userService;
  38. private final SysPermissionService permissionService;
  39. /**
  40. * 登录方法
  41. *
  42. * @param loginBody 登录信息
  43. * @return 结果
  44. */
  45. @Anonymous
  46. @PostMapping("/login")
  47. public R<Map<String, Object>> login(@Validated @RequestBody LoginBody loginBody) {
  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 R.ok(ajax);
  54. }
  55. /**
  56. * 短信登录(示例)
  57. *
  58. * @param smsLoginBody 登录信息
  59. * @return 结果
  60. */
  61. @Anonymous
  62. @PostMapping("/smsLogin")
  63. public R<Map<String, Object>> smsLogin(@Validated @RequestBody SmsLoginBody smsLoginBody) {
  64. Map<String, Object> ajax = new HashMap<>();
  65. // 生成令牌
  66. String token = loginService.smsLogin(smsLoginBody.getPhonenumber(), smsLoginBody.getSmsCode());
  67. ajax.put(Constants.TOKEN, token);
  68. return R.ok(ajax);
  69. }
  70. /**
  71. * 小程序登录(示例)
  72. *
  73. * @param xcxCode 小程序code
  74. * @return 结果
  75. */
  76. @Anonymous
  77. @PostMapping("/xcxLogin")
  78. public R<Map<String, Object>> xcxLogin(@NotBlank(message = "{xcx.code.not.blank}") String xcxCode) {
  79. Map<String, Object> ajax = new HashMap<>();
  80. // 生成令牌
  81. String token = loginService.xcxLogin(xcxCode);
  82. ajax.put(Constants.TOKEN, token);
  83. return R.ok(ajax);
  84. }
  85. /**
  86. * 退出登录
  87. */
  88. @Anonymous
  89. @PostMapping("/logout")
  90. public R<Void> logout() {
  91. loginService.logout();
  92. return R.ok("退出成功");
  93. }
  94. /**
  95. * 获取用户信息
  96. *
  97. * @return 用户信息
  98. */
  99. @GetMapping("getInfo")
  100. public R<Map<String, Object>> getInfo() {
  101. SysUser user = userService.selectUserById(LoginHelper.getUserId());
  102. // 角色集合
  103. Set<String> roles = permissionService.getRolePermission(user);
  104. // 权限集合
  105. Set<String> permissions = permissionService.getMenuPermission(user);
  106. Map<String, Object> ajax = new HashMap<>();
  107. ajax.put("user", user);
  108. ajax.put("roles", roles);
  109. ajax.put("permissions", permissions);
  110. return R.ok(ajax);
  111. }
  112. /**
  113. * 获取路由信息
  114. *
  115. * @return 路由信息
  116. */
  117. @GetMapping("getRouters")
  118. public R<List<RouterVo>> getRouters() {
  119. Long userId = LoginHelper.getUserId();
  120. List<SysMenu> menus = menuService.selectMenuTreeByUserId(userId);
  121. return R.ok(menuService.buildMenus(menus));
  122. }
  123. }