mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 12:18:42 +08:00 
			
		
		
		
	Merge branch 'develop' of https://gitee.com/zhijiantianya/ruoyi-vue-pro into master-jdk17
# Conflicts: # yudao-module-pay/yudao-module-pay-biz/src/main/java/cn/iocoder/yudao/module/pay/service/wallet/PayWalletServiceImpl.java
This commit is contained in:
		@@ -115,6 +115,13 @@ public class AuthController {
 | 
			
		||||
        return success(AuthConvert.INSTANCE.convert(user, roles, menuList));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @PostMapping("/register")
 | 
			
		||||
    @PermitAll
 | 
			
		||||
    @Operation(summary = "注册用户")
 | 
			
		||||
    public CommonResult<AuthLoginRespVO> register(@RequestBody @Valid AuthRegisterReqVO registerReqVO) {
 | 
			
		||||
        return success(authService.register(registerReqVO));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // ========== 短信登录相关 ==========
 | 
			
		||||
 | 
			
		||||
    @PostMapping("/sms-login")
 | 
			
		||||
 
 | 
			
		||||
@@ -0,0 +1,37 @@
 | 
			
		||||
package cn.iocoder.yudao.module.system.controller.admin.auth.vo;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
import io.swagger.v3.oas.annotations.media.Schema;
 | 
			
		||||
import lombok.Data;
 | 
			
		||||
import org.hibernate.validator.constraints.Length;
 | 
			
		||||
 | 
			
		||||
import jakarta.validation.constraints.*;
 | 
			
		||||
 | 
			
		||||
@Schema(description = "管理后台 - Register Request VO")
 | 
			
		||||
@Data
 | 
			
		||||
public class AuthRegisterReqVO {
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "用户账号", requiredMode = Schema.RequiredMode.REQUIRED, example = "yudao")
 | 
			
		||||
    @NotBlank(message = "用户账号不能为空")
 | 
			
		||||
    @Pattern(regexp = "^[a-zA-Z0-9]{4,30}$", message = "用户账号由 数字、字母 组成")
 | 
			
		||||
    @Size(min = 4, max = 30, message = "用户账号长度为 4-30 个字符")
 | 
			
		||||
    private String username;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "用户昵称", requiredMode = Schema.RequiredMode.REQUIRED, example = "芋艿")
 | 
			
		||||
    @NotBlank(message = "用户昵称不能为空")
 | 
			
		||||
    @Size(max = 30, message = "用户昵称长度不能超过 30 个字符")
 | 
			
		||||
    private String nickname;
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "密码", requiredMode = Schema.RequiredMode.REQUIRED, example = "123456")
 | 
			
		||||
    @NotEmpty(message = "密码不能为空")
 | 
			
		||||
    @Length(min = 4, max = 16, message = "密码长度为 4-16 位")
 | 
			
		||||
    private String password;
 | 
			
		||||
 | 
			
		||||
    // ========== 图片验证码相关 ==========
 | 
			
		||||
 | 
			
		||||
    @Schema(description = "验证码,验证码开启时,需要传递", requiredMode = Schema.RequiredMode.REQUIRED,
 | 
			
		||||
            example = "PfcH6mgr8tpXuMWFjvW6YVaqrswIuwmWI5dsVZSg7sGpWtDCUbHuDEXl3cFB1+VvCC/rAkSwK8Fad52FSuncVg==")
 | 
			
		||||
    @NotEmpty(message = "验证码不能为空", groups = AuthLoginReqVO.CodeEnableGroup.class)
 | 
			
		||||
    private String captchaVerification;
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
@@ -70,4 +70,12 @@ public interface AdminAuthService {
 | 
			
		||||
     */
 | 
			
		||||
    AuthLoginRespVO refreshToken(String refreshToken);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 用户注册
 | 
			
		||||
     *
 | 
			
		||||
     * @param createReqVO 注册用户
 | 
			
		||||
     * @return 注册结果
 | 
			
		||||
     */
 | 
			
		||||
    AuthLoginRespVO register(AuthRegisterReqVO createReqVO);
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -27,12 +27,12 @@ import com.google.common.annotations.VisibleForTesting;
 | 
			
		||||
import com.xingyuv.captcha.model.common.ResponseModel;
 | 
			
		||||
import com.xingyuv.captcha.model.vo.CaptchaVO;
 | 
			
		||||
import com.xingyuv.captcha.service.CaptchaService;
 | 
			
		||||
import jakarta.annotation.Resource;
 | 
			
		||||
import jakarta.validation.Validator;
 | 
			
		||||
import lombok.extern.slf4j.Slf4j;
 | 
			
		||||
import org.springframework.beans.factory.annotation.Value;
 | 
			
		||||
import org.springframework.stereotype.Service;
 | 
			
		||||
 | 
			
		||||
import jakarta.annotation.Resource;
 | 
			
		||||
import jakarta.validation.Validator;
 | 
			
		||||
import java.util.Objects;
 | 
			
		||||
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
 | 
			
		||||
@@ -247,4 +247,33 @@ public class AdminAuthServiceImpl implements AdminAuthService {
 | 
			
		||||
        return UserTypeEnum.ADMIN;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public AuthLoginRespVO register(AuthRegisterReqVO registerReqVO) {
 | 
			
		||||
        // 1. 校验验证码
 | 
			
		||||
        validateCaptcha(registerReqVO);
 | 
			
		||||
 | 
			
		||||
        // 2. 校验用户名是否已存在
 | 
			
		||||
        Long userId = userService.registerUser(registerReqVO);
 | 
			
		||||
 | 
			
		||||
        // 3. 创建 Token 令牌,记录登录日志
 | 
			
		||||
        return createTokenAfterLoginSuccess(userId, registerReqVO.getUsername(), LoginLogTypeEnum.LOGIN_USERNAME);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @VisibleForTesting
 | 
			
		||||
    void validateCaptcha(AuthRegisterReqVO reqVO) {
 | 
			
		||||
        // 如果验证码关闭,则不进行校验
 | 
			
		||||
        if (!captchaEnable) {
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
        // 校验验证码
 | 
			
		||||
        ValidationUtils.validate(validator, reqVO, AuthLoginReqVO.CodeEnableGroup.class);
 | 
			
		||||
        CaptchaVO captchaVO = new CaptchaVO();
 | 
			
		||||
        captchaVO.setCaptchaVerification(reqVO.getCaptchaVerification());
 | 
			
		||||
        ResponseModel response = captchaService.verification(captchaVO);
 | 
			
		||||
        // 验证不通过
 | 
			
		||||
        if (!response.isSuccess()) {
 | 
			
		||||
            throw exception(AUTH_REGISTER_CAPTCHA_CODE_ERROR, response.getRepMsg());
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,16 +1,23 @@
 | 
			
		||||
package cn.iocoder.yudao.module.system.service.user;
 | 
			
		||||
 | 
			
		||||
import cn.hutool.core.collection.CollUtil;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.util.collection.CollectionUtils;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.auth.vo.AuthRegisterReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.profile.UserProfileUpdatePasswordReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.profile.UserProfileUpdateReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.*;
 | 
			
		||||
import cn.iocoder.yudao.framework.common.pojo.PageResult;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserImportExcelVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserImportRespVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserPageReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserSaveReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.dal.dataobject.user.AdminUserDO;
 | 
			
		||||
 | 
			
		||||
import jakarta.validation.Valid;
 | 
			
		||||
 | 
			
		||||
import java.io.InputStream;
 | 
			
		||||
import java.util.*;
 | 
			
		||||
import java.util.Collection;
 | 
			
		||||
import java.util.HashMap;
 | 
			
		||||
import java.util.List;
 | 
			
		||||
import java.util.Map;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * 后台用户 Service 接口
 | 
			
		||||
@@ -27,6 +34,14 @@ public interface AdminUserService {
 | 
			
		||||
     */
 | 
			
		||||
    Long createUser(@Valid UserSaveReqVO createReqVO);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 注册用户
 | 
			
		||||
     *
 | 
			
		||||
     * @param registerReqVO 用户信息
 | 
			
		||||
     * @return 用户编号
 | 
			
		||||
     */
 | 
			
		||||
    Long registerUser(@Valid AuthRegisterReqVO registerReqVO);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 修改用户
 | 
			
		||||
     *
 | 
			
		||||
 
 | 
			
		||||
@@ -13,6 +13,7 @@ import cn.iocoder.yudao.framework.common.util.validation.ValidationUtils;
 | 
			
		||||
import cn.iocoder.yudao.framework.datapermission.core.util.DataPermissionUtils;
 | 
			
		||||
import cn.iocoder.yudao.module.infra.api.config.ConfigApi;
 | 
			
		||||
import cn.iocoder.yudao.module.infra.api.file.FileApi;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.auth.vo.AuthRegisterReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.profile.UserProfileUpdatePasswordReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.profile.UserProfileUpdateReqVO;
 | 
			
		||||
import cn.iocoder.yudao.module.system.controller.admin.user.vo.user.UserImportExcelVO;
 | 
			
		||||
@@ -115,6 +116,26 @@ public class AdminUserServiceImpl implements AdminUserService {
 | 
			
		||||
        return user.getId();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    public Long registerUser(AuthRegisterReqVO registerReqVO) {
 | 
			
		||||
        // 1.1 校验账户配合
 | 
			
		||||
        tenantService.handleTenantInfo(tenant -> {
 | 
			
		||||
            long count = userMapper.selectCount();
 | 
			
		||||
            if (count >= tenant.getAccountCount()) {
 | 
			
		||||
                throw exception(USER_COUNT_MAX, tenant.getAccountCount());
 | 
			
		||||
            }
 | 
			
		||||
        });
 | 
			
		||||
        // 1.2 校验正确性
 | 
			
		||||
        validateUserForCreateOrUpdate(null, registerReqVO.getUsername(), null, null, null, null);
 | 
			
		||||
 | 
			
		||||
        // 2. 插入用户
 | 
			
		||||
        AdminUserDO user = BeanUtils.toBean(registerReqVO, AdminUserDO.class);
 | 
			
		||||
        user.setStatus(CommonStatusEnum.ENABLE.getStatus()); // 默认开启
 | 
			
		||||
        user.setPassword(encodePassword(registerReqVO.getPassword())); // 加密密码
 | 
			
		||||
        userMapper.insert(user);
 | 
			
		||||
        return user.getId();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    @Transactional(rollbackFor = Exception.class)
 | 
			
		||||
    @LogRecord(type = SYSTEM_USER_TYPE, subType = SYSTEM_USER_UPDATE_SUB_TYPE, bizNo = "{{#updateReqVO.id}}",
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user