mirror of
				https://gitee.com/hhyykk/ipms-sjy.git
				synced 2025-11-04 04:08:43 +08:00 
			
		
		
		
	✨ Member:社交登录逻辑调整,如果登录时无用户,则自动创建用户,保持和各 App 统一逻辑
This commit is contained in:
		@@ -73,9 +73,8 @@ public class AppAuthController {
 | 
			
		||||
 | 
			
		||||
    @PostMapping("/sms-login")
 | 
			
		||||
    @Operation(summary = "使用手机 + 验证码登录")
 | 
			
		||||
    public CommonResult<AppAuthLoginRespVO> smsLogin(@RequestBody @Valid AppAuthSmsLoginReqVO reqVO,
 | 
			
		||||
                                                     @RequestHeader Integer terminal) {
 | 
			
		||||
        return success(authService.smsLogin(reqVO, terminal));
 | 
			
		||||
    public CommonResult<AppAuthLoginRespVO> smsLogin(@RequestBody @Valid AppAuthSmsLoginReqVO reqVO) {
 | 
			
		||||
        return success(authService.smsLogin(reqVO));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @PostMapping("/send-sms-code")
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,5 @@
 | 
			
		||||
package cn.iocoder.yudao.module.member.service.auth;
 | 
			
		||||
 | 
			
		||||
import cn.iocoder.yudao.framework.common.enums.TerminalEnum;
 | 
			
		||||
import cn.iocoder.yudao.module.member.controller.app.auth.vo.*;
 | 
			
		||||
 | 
			
		||||
import jakarta.validation.Valid;
 | 
			
		||||
@@ -33,10 +32,9 @@ public interface MemberAuthService {
 | 
			
		||||
     * 手机 + 验证码登陆
 | 
			
		||||
     *
 | 
			
		||||
     * @param reqVO    登陆信息
 | 
			
		||||
     * @param terminal 终端 {@link TerminalEnum}
 | 
			
		||||
     * @return 登录结果
 | 
			
		||||
     */
 | 
			
		||||
    AppAuthLoginRespVO smsLogin(@Valid AppAuthSmsLoginReqVO reqVO, Integer terminal);
 | 
			
		||||
    AppAuthLoginRespVO smsLogin(@Valid AppAuthSmsLoginReqVO reqVO);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 社交登录,使用 code 授权码
 | 
			
		||||
 
 | 
			
		||||
@@ -36,6 +36,7 @@ import java.util.Objects;
 | 
			
		||||
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
 | 
			
		||||
import static cn.iocoder.yudao.framework.common.util.servlet.ServletUtils.getClientIP;
 | 
			
		||||
import static cn.iocoder.yudao.framework.web.core.util.WebFrameworkUtils.getTerminal;
 | 
			
		||||
import static cn.iocoder.yudao.module.member.enums.ErrorCodeConstants.*;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -78,13 +79,13 @@ public class MemberAuthServiceImpl implements MemberAuthService {
 | 
			
		||||
 | 
			
		||||
    @Override
 | 
			
		||||
    @Transactional
 | 
			
		||||
    public AppAuthLoginRespVO smsLogin(AppAuthSmsLoginReqVO reqVO, Integer terminal) {
 | 
			
		||||
    public AppAuthLoginRespVO smsLogin(AppAuthSmsLoginReqVO reqVO) {
 | 
			
		||||
        // 校验验证码
 | 
			
		||||
        String userIp = getClientIP();
 | 
			
		||||
        smsCodeApi.useSmsCode(AuthConvert.INSTANCE.convert(reqVO, SmsSceneEnum.MEMBER_LOGIN.getScene(), userIp));
 | 
			
		||||
 | 
			
		||||
        // 获得获得注册用户
 | 
			
		||||
        MemberUserDO user = userService.createUserIfAbsent(reqVO.getMobile(), userIp, terminal);
 | 
			
		||||
        MemberUserDO user = userService.createUserIfAbsent(reqVO.getMobile(), userIp, getTerminal());
 | 
			
		||||
        Assert.notNull(user, "获取用户失败,结果为空");
 | 
			
		||||
 | 
			
		||||
        // 如果 socialType 非空,说明需要绑定社交用户
 | 
			
		||||
@@ -107,10 +108,13 @@ public class MemberAuthServiceImpl implements MemberAuthService {
 | 
			
		||||
            throw exception(AUTH_THIRD_LOGIN_NOT_BIND);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // 自动登录
 | 
			
		||||
        // 情况一:已绑定,自动登录
 | 
			
		||||
        MemberUserDO user = userService.getUser(socialUser.getUserId());
 | 
			
		||||
        if (user == null) {
 | 
			
		||||
            throw exception(USER_NOT_EXISTS);
 | 
			
		||||
        // 情况二:未绑定,注册登录
 | 
			
		||||
        } else {
 | 
			
		||||
            user = userService.createUser(user.getNickname(), user.getAvatar(), getClientIP(), getTerminal());
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        // 创建 Token 令牌,记录登录日志
 | 
			
		||||
 
 | 
			
		||||
@@ -49,6 +49,18 @@ public interface MemberUserService {
 | 
			
		||||
     */
 | 
			
		||||
    MemberUserDO createUserIfAbsent(@Mobile String mobile, String registerIp, Integer terminal);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 创建用户
 | 
			
		||||
     * 目的:三方登录时,如果未绑定用户时,自动创建对应用户
 | 
			
		||||
     *
 | 
			
		||||
     * @param nickname   昵称
 | 
			
		||||
     * @param avtar      头像
 | 
			
		||||
     * @param registerIp 注册 IP
 | 
			
		||||
     * @param terminal   终端 {@link TerminalEnum}
 | 
			
		||||
     * @return 用户对象
 | 
			
		||||
     */
 | 
			
		||||
    MemberUserDO createUser(String nickname, String avtar, String registerIp, Integer terminal);
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * 更新用户的最后登陆信息
 | 
			
		||||
     *
 | 
			
		||||
 
 | 
			
		||||
@@ -81,10 +81,17 @@ public class MemberUserServiceImpl implements MemberUserService {
 | 
			
		||||
            return user;
 | 
			
		||||
        }
 | 
			
		||||
        // 用户不存在,则进行创建
 | 
			
		||||
        return createUser(mobile, registerIp, terminal);
 | 
			
		||||
        return createUser(mobile, null, null, registerIp, terminal);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private MemberUserDO createUser(String mobile, String registerIp, Integer terminal) {
 | 
			
		||||
    @Override
 | 
			
		||||
    @Transactional(rollbackFor = Exception.class)
 | 
			
		||||
    public MemberUserDO createUser(String nickname, String avtar, String registerIp, Integer terminal) {
 | 
			
		||||
        return createUser(null, nickname, avtar, registerIp, terminal);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    private MemberUserDO createUser(String mobile, String nickname, String avtar,
 | 
			
		||||
                                    String registerIp, Integer terminal) {
 | 
			
		||||
        // 生成密码
 | 
			
		||||
        String password = IdUtil.fastSimpleUUID();
 | 
			
		||||
        // 插入用户
 | 
			
		||||
@@ -92,8 +99,8 @@ public class MemberUserServiceImpl implements MemberUserService {
 | 
			
		||||
        user.setMobile(mobile);
 | 
			
		||||
        user.setStatus(CommonStatusEnum.ENABLE.getStatus()); // 默认开启
 | 
			
		||||
        user.setPassword(encodePassword(password)); // 加密密码
 | 
			
		||||
        user.setRegisterIp(registerIp);
 | 
			
		||||
        user.setRegisterTerminal(terminal);
 | 
			
		||||
        user.setRegisterIp(registerIp).setRegisterTerminal(terminal);
 | 
			
		||||
        user.setNickname(nickname).setAvatar(avtar); // 基础信息
 | 
			
		||||
        memberUserMapper.insert(user);
 | 
			
		||||
 | 
			
		||||
        // 发送 MQ 消息:用户创建
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user