AuthenticationController.java 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package com.izouma.nineth.web;
  2. import com.izouma.nineth.domain.User;
  3. import com.izouma.nineth.enums.AuthorityName;
  4. import com.izouma.nineth.exception.AuthenticationException;
  5. import com.izouma.nineth.exception.BusinessException;
  6. import com.izouma.nineth.security.JwtTokenUtil;
  7. import com.izouma.nineth.security.JwtUser;
  8. import com.izouma.nineth.security.JwtUserFactory;
  9. import com.izouma.nineth.service.CacheService;
  10. import com.izouma.nineth.service.CaptchaService;
  11. import com.izouma.nineth.service.UserService;
  12. import io.swagger.annotations.ApiOperation;
  13. import lombok.AllArgsConstructor;
  14. import lombok.extern.slf4j.Slf4j;
  15. import org.springframework.security.authentication.AuthenticationManager;
  16. import org.springframework.security.authentication.BadCredentialsException;
  17. import org.springframework.security.authentication.DisabledException;
  18. import org.springframework.security.authentication.UsernamePasswordAuthenticationToken;
  19. import org.springframework.security.core.Authentication;
  20. import org.springframework.security.core.authority.SimpleGrantedAuthority;
  21. import org.springframework.web.bind.annotation.GetMapping;
  22. import org.springframework.web.bind.annotation.PostMapping;
  23. import org.springframework.web.bind.annotation.RequestMapping;
  24. import org.springframework.web.bind.annotation.RestController;
  25. import java.util.Objects;
  26. @Slf4j
  27. @AllArgsConstructor
  28. @RestController
  29. @RequestMapping("/auth")
  30. public class AuthenticationController {
  31. private final AuthenticationManager authenticationManager;
  32. private final JwtTokenUtil jwtTokenUtil;
  33. private final UserService userService;
  34. private final CaptchaService captchaService;
  35. @PostMapping("/login")
  36. public String loginByUserPwd(String username, String password, Integer expiration) {
  37. Authentication authentication = authenticate(username, password);
  38. JwtUser jwtUser = (JwtUser) authentication.getPrincipal();
  39. return jwtTokenUtil.generateToken(jwtUser);
  40. }
  41. @PostMapping("/loginAdmin")
  42. public String loginByUserPwdAdmin(String username, String password, Integer expiration) {
  43. Authentication authentication = authenticate(username, password);
  44. if (!authentication.getAuthorities().contains(new SimpleGrantedAuthority(AuthorityName.ROLE_ADMIN.name()))) {
  45. throw new AuthenticationException("禁止登录", null);
  46. }
  47. JwtUser jwtUser = (JwtUser) authentication.getPrincipal();
  48. return jwtTokenUtil.generateToken(jwtUser);
  49. }
  50. @PostMapping("/phoneLogin")
  51. @ApiOperation(value = "手机号验证码登录")
  52. public String phoneLogin(String phone, String code) {
  53. User user = userService.loginByPhone(phone, code);
  54. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  55. }
  56. @PostMapping("/phonePwdLogin")
  57. @ApiOperation(value = "手机号密码登录")
  58. public String phonePwdLogin(String phone, String password) {
  59. User user = userService.loginByPhonePwd(phone, password);
  60. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  61. }
  62. @PostMapping("/phoneRegister")
  63. @ApiOperation(value = "手机号密码注册")
  64. public String phonePwdLogin(String phone, String code, String password, String inviteCode, Long invitor,
  65. Long collectionId, String captcha, String captchaKey) {
  66. boolean verify = captchaService.verify(captcha, captchaKey);
  67. if (!verify){
  68. throw new BusinessException("验证码错误");
  69. }
  70. User user = userService.phoneRegister(phone, code, password, inviteCode, invitor, collectionId);
  71. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  72. }
  73. @PostMapping("/mpLogin")
  74. @ApiOperation(value = "公众号登录")
  75. public String mpLogin(String code) {
  76. try {
  77. User user = userService.loginMp(code);
  78. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  79. } catch (Exception e) {
  80. log.error("loginByCode", e);
  81. throw new AuthenticationException("登陆错误", e);
  82. }
  83. }
  84. @PostMapping("/maLogin")
  85. @ApiOperation(value = "小程序登录")
  86. public String maLogin(String code) {
  87. try {
  88. User user = userService.loginMa(code);
  89. return jwtTokenUtil.generateToken(JwtUserFactory.create(user));
  90. } catch (Exception e) {
  91. log.error("loginByCode", e);
  92. throw new AuthenticationException("登陆错误", e);
  93. }
  94. }
  95. @GetMapping("/getTime")
  96. public Long getTime() {
  97. return System.currentTimeMillis();
  98. }
  99. /**
  100. * Authenticates the user. If something is wrong, an {@link AuthenticationException} will be thrown
  101. *
  102. * @return Authentication
  103. */
  104. private Authentication authenticate(String username, String password) {
  105. Objects.requireNonNull(username);
  106. Objects.requireNonNull(password);
  107. try {
  108. return authenticationManager.authenticate(new UsernamePasswordAuthenticationToken(username, password));
  109. } catch (DisabledException e) {
  110. throw new AuthenticationException("禁止登录", e);
  111. } catch (BadCredentialsException e) {
  112. throw new AuthenticationException("用户名或密码错误", e);
  113. }
  114. }
  115. }