SysRegisterService.java 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package com.ruoyi.system.service;
  2. import cn.dev33.satoken.secure.BCrypt;
  3. import com.ruoyi.common.constant.CacheConstants;
  4. import com.ruoyi.common.constant.Constants;
  5. import com.ruoyi.common.constant.UserConstants;
  6. import com.ruoyi.common.core.domain.event.LogininforEvent;
  7. import com.ruoyi.common.core.domain.entity.SysUser;
  8. import com.ruoyi.common.core.domain.model.RegisterBody;
  9. import com.ruoyi.common.enums.UserType;
  10. import com.ruoyi.common.exception.user.CaptchaException;
  11. import com.ruoyi.common.exception.user.CaptchaExpireException;
  12. import com.ruoyi.common.exception.user.UserException;
  13. import com.ruoyi.common.utils.MessageUtils;
  14. import com.ruoyi.common.utils.ServletUtils;
  15. import com.ruoyi.common.utils.StringUtils;
  16. import com.ruoyi.common.utils.redis.RedisUtils;
  17. import com.ruoyi.common.utils.spring.SpringUtils;
  18. import lombok.RequiredArgsConstructor;
  19. import org.springframework.stereotype.Service;
  20. import javax.servlet.http.HttpServletRequest;
  21. /**
  22. * 注册校验方法
  23. *
  24. * @author Lion Li
  25. */
  26. @RequiredArgsConstructor
  27. @Service
  28. public class SysRegisterService {
  29. private final ISysUserService userService;
  30. private final ISysConfigService configService;
  31. /**
  32. * 注册
  33. */
  34. public void register(RegisterBody registerBody) {
  35. HttpServletRequest request = ServletUtils.getRequest();
  36. String username = registerBody.getUsername();
  37. String password = registerBody.getPassword();
  38. // 校验用户类型是否存在
  39. String userType = UserType.getUserType(registerBody.getUserType()).getUserType();
  40. boolean captchaEnabled = configService.selectCaptchaEnabled();
  41. // 验证码开关
  42. if (captchaEnabled) {
  43. validateCaptcha(username, registerBody.getCode(), registerBody.getUuid(), request);
  44. }
  45. SysUser sysUser = new SysUser();
  46. sysUser.setUserName(username);
  47. sysUser.setNickName(username);
  48. sysUser.setPassword(BCrypt.hashpw(password));
  49. sysUser.setUserType(userType);
  50. if (!userService.checkUserNameUnique(sysUser)) {
  51. throw new UserException("user.register.save.error", username);
  52. }
  53. boolean regFlag = userService.registerUser(sysUser);
  54. if (!regFlag) {
  55. throw new UserException("user.register.error");
  56. }
  57. recordLogininfor(username, Constants.REGISTER, MessageUtils.message("user.register.success"));
  58. }
  59. /**
  60. * 校验验证码
  61. *
  62. * @param username 用户名
  63. * @param code 验证码
  64. * @param uuid 唯一标识
  65. * @return 结果
  66. */
  67. public void validateCaptcha(String username, String code, String uuid, HttpServletRequest request) {
  68. String verifyKey = CacheConstants.CAPTCHA_CODE_KEY + StringUtils.defaultString(uuid, "");
  69. String captcha = RedisUtils.getCacheObject(verifyKey);
  70. RedisUtils.deleteObject(verifyKey);
  71. if (captcha == null) {
  72. recordLogininfor(username, Constants.REGISTER, MessageUtils.message("user.jcaptcha.expire"));
  73. throw new CaptchaExpireException();
  74. }
  75. if (!code.equalsIgnoreCase(captcha)) {
  76. recordLogininfor(username, Constants.REGISTER, MessageUtils.message("user.jcaptcha.error"));
  77. throw new CaptchaException();
  78. }
  79. }
  80. /**
  81. * 记录登录信息
  82. *
  83. * @param username 用户名
  84. * @param status 状态
  85. * @param message 消息内容
  86. * @return
  87. */
  88. private void recordLogininfor(String username, String status, String message) {
  89. LogininforEvent logininforEvent = new LogininforEvent();
  90. logininforEvent.setUsername(username);
  91. logininforEvent.setStatus(status);
  92. logininforEvent.setMessage(message);
  93. logininforEvent.setRequest(ServletUtils.getRequest());
  94. SpringUtils.context().publishEvent(logininforEvent);
  95. }
  96. }