AuthenticationController.java 4.6 KB

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