MrShi
2025-09-15 856f526f823f5dad88c28657d82f971ff66afb1e
server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
@@ -2,6 +2,7 @@
import cn.binarywang.wx.miniapp.bean.WxMaJscode2SessionResult;
import cn.binarywang.wx.miniapp.bean.WxMaPhoneNumberInfo;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
@@ -24,7 +25,10 @@
import com.doumee.dao.business.web.response.AccountResponse;
import com.doumee.dao.business.web.response.HomeResponse;
import com.doumee.dao.business.web.response.UserResponse;
import com.doumee.dao.system.SystemUserMapper;
import com.doumee.dao.system.model.SystemUser;
import com.doumee.service.business.MemberService;
import lombok.extern.slf4j.Slf4j;
import me.chanjar.weixin.common.error.WxErrorException;
import org.apache.commons.lang3.StringUtils;
import org.apache.shiro.SecurityUtils;
@@ -46,10 +50,13 @@
 * @date 2023/09/27 18:06
 */
@Service
@Slf4j
public class MemberServiceImpl implements MemberService {
    @Autowired
    private MemberMapper memberMapper;
    @Autowired
    private SystemUserMapper systemUserMapper;
    @Override
@@ -57,6 +64,7 @@
        memberMapper.insert(member);
        return member.getId();
    }
    @Override
    public String createManageMember(Member member) {
@@ -67,7 +75,7 @@
                .eq(Member::getIsdeleted,Constants.ZERO)
                .eq(Member::getType,Constants.ONE)
                .eq(Member::getCardNo,member.getCardNo());
        Integer integer = memberMapper.selectCount(wrapper);
        long integer = memberMapper.selectCount(wrapper);
        if (integer > 0){
            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"卡号存在重复");
@@ -79,13 +87,13 @@
        insert.setEditor(principal.getId());
        insert.setIsdeleted(Constants.ZERO);
        insert.setName(member.getName());
        insert.setName(member.getNickname());
        insert.setStatus(Constants.ZERO);
        insert.setNickname(member.getNickname());
        insert.setStatus(member.getStatus());
        insert.setRegisterDate(new Date());
        insert.setCardNo(member.getCardNo());
        insert.setType(Constants.ONE);
        memberMapper.insert(member);
        return member.getId();
        memberMapper.insert(insert);
        return insert.getId();
    }
    @Override
@@ -114,6 +122,16 @@
    @Override
    public void update(Member member) {
        QueryWrapper<Member> wrapper = new QueryWrapper<>();
        wrapper.lambda()
                .eq(Member::getIsdeleted,Constants.ZERO)
                .eq(Member::getType,Constants.ONE)
                .eq(Member::getCardNo,member.getCardNo());
        Member member1 = memberMapper.selectOne(wrapper);
        if (Objects.nonNull(member1) && !member1.getId().equals(member.getId())){
            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"卡号存在重复");
        }
        LoginUserInfo principal = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
        Member update = new Member();
        update.setId(member.getId());
@@ -143,7 +161,7 @@
    @Override
    public Member findOne(Member member) {
        QueryWrapper<Member> wrapper = new QueryWrapper<>(member);
        return memberMapper.selectOne(wrapper);
        return memberMapper.selectOne(wrapper.last(" limit 1"));
    }
    @Override
@@ -181,7 +199,7 @@
            queryWrapper.lambda().eq(Member::getInfo, pageWrap.getModel().getInfo());
        }
        if (pageWrap.getModel().getName() != null) {
            queryWrapper.lambda().eq(Member::getName, pageWrap.getModel().getName());
            queryWrapper.lambda().like(Member::getName, pageWrap.getModel().getName());
        }
        if (pageWrap.getModel().getNickname() != null) {
            queryWrapper.lambda().eq(Member::getNickname, pageWrap.getModel().getNickname());
@@ -219,7 +237,7 @@
            queryWrapper.lambda().eq(Member::getPassword, pageWrap.getModel().getPassword());
        }
        if (pageWrap.getModel().getCardNo() != null) {
            queryWrapper.lambda().eq(Member::getCardNo, pageWrap.getModel().getCardNo());
            queryWrapper.lambda().like(Member::getCardNo, pageWrap.getModel().getCardNo());
        }
        if (pageWrap.getModel().getCardSign() != null) {
            queryWrapper.lambda().eq(Member::getCardSign, pageWrap.getModel().getCardSign());
@@ -305,9 +323,11 @@
     */
    @Override
    public AccountResponse wxLogin(String code) {
        log.error("================================"+code+ JSONObject.toJSONString( WxMiniConfig.wxMaService.getWxMaConfig()));
        try {
            //获取微信敏感数据
            WxMaJscode2SessionResult session = WxMiniConfig.wxMaService.getUserService().getSessionInfo(code);
            log.error("================================"+ JSONObject.toJSONString(session));
            String openId = session.getOpenid();
            String unionId = session.getUnionid();
            if (StringUtils.isBlank(openId)) {
@@ -318,31 +338,30 @@
            if(Objects.isNull(member)){
                //新增用户 需要进行用户绑定手机号
                member = new Member();
                member.setId(Constants.getUUID());
                member.setCreateDate(new Date());
                member.setIsdeleted(Constants.ZERO);
                member.setOpenid(openId);
                member.setUnionid(unionId);
                member.setType(Constants.ZERO);
                member.setRegisterDate(new Date());
                member.setOrigin(Constants.ZERO.toString());
                member.setStatus(Constants.ZERO);
                memberMapper.insert(member);
                accountResponse.setStatus(Constants.ONE);
            }else{
                UserResponse userResponse = getUserInfo(member.getId());
                if(StringUtils.isBlank(member.getPhone())){
                    accountResponse.setStatus(Constants.ONE);
                }else{
                    JwtPayLoad payLoad = new JwtPayLoad(userResponse.getId());
                    accountResponse.setToken(JwtTokenUtil.generateToken(payLoad));
                }
                accountResponse.setUserResponse(userResponse);
            }
            UserResponse userResponse = getUserInfo(member.getId());
            if(StringUtils.isBlank(member.getPhone())){
                accountResponse.setStatus(Constants.ONE);
            }
            JwtPayLoad payLoad = new JwtPayLoad(member.getId());
            accountResponse.setToken(JwtTokenUtil.generateToken(payLoad));
            accountResponse.setSessionKey(session.getSessionKey());
            accountResponse.setUserResponse(userResponse);
            return accountResponse;
        } catch (WxErrorException e) {
            log.error(e.getMessage());
            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(), "微信登录异常!请联系管理员");
        }
    }
@@ -383,9 +402,20 @@
        UserResponse userResponse = new UserResponse();
        BeanUtils.copyProperties(member,userResponse);
        userResponse.setMobile(member.getPhone());
        if(member.getSysuserId()!=null){
            SystemUser user= systemUserMapper.selectById(member.getSysuserId());
            if(user !=null && !Constants.equalsInteger(user.getDeleted(),Constants.ONE)
                    &&  !Constants.equalsInteger(user.getStatus(),Constants.ONE)){
                SystemUser u = new SystemUser();
                u.setId(user.getId());
                u.setUsername(user.getUsername());
                u.setNickname(user.getNickname());
                u.setRealname(user.getRealname());
                userResponse.setSysuser(u);
            }
        }
        return userResponse;
    }
}