From 356b6e4b0a11a6e44717dc9b92beaacc9c0c4b7a Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期二, 06 八月 2024 10:13:18 +0800 Subject: [PATCH] 修改bug --- ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java | 67 +++++++++++++++++---------------- 1 files changed, 35 insertions(+), 32 deletions(-) diff --git a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java index 7a0e9a8..aeced8b 100644 --- a/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java +++ b/ruoyi-modules/ruoyi-member/src/main/java/com/ruoyi/member/service/impl/MemberServiceImpl.java @@ -37,7 +37,6 @@ import com.ruoyi.member.service.IMemberService; import com.ruoyi.member.util.HttpUtils; import com.ruoyi.system.api.RemoteUserService; -import com.ruoyi.system.api.constants.SecurityConstant; import com.ruoyi.system.api.domain.AppMiniLoginVO; import com.ruoyi.system.api.domain.Member; import com.ruoyi.system.api.domain.MemberPoints; @@ -54,7 +53,6 @@ import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.concurrent.TimeUnit; import javax.annotation.Resource; import org.apache.commons.io.IOUtils; import org.apache.http.HttpEntity; @@ -66,6 +64,8 @@ import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Propagation; +import org.springframework.transaction.annotation.Transactional; /** * <p> @@ -192,7 +192,7 @@ sysUser.setNickName("白金用户"); sysUser.setUserType("03"); sysUser.setPhonenumber(response.getOpenId()); - sysUser.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); + sysUser.setAvatar("https://jyzx-obs.obs.cn-sccd1.ctyun.cn/d41508d822cb4b7896aaa1bb56e6167f.png"); String password = "123456"; sysUser.setPassword(SecurityUtils.encryptPassword(password)); sysUser = sysUserService.registerUser(sysUser).getData(); @@ -204,7 +204,7 @@ member.setDelFlag(0); member.setNickname("白酒用户"); member.setPhone(appMiniLoginDto.getPhone()); - member.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); + member.setAvatar("https://jyzx-obs.obs.cn-sccd1.ctyun.cn/d41508d822cb4b7896aaa1bb56e6167f.png"); member.setZfbOpenid(response.getOpenId()); this.save(member); appMiniLoginVo.setZfbuserid(response.getUserId()); @@ -243,14 +243,13 @@ Member member1=this.getOne(wrapper1); if (member1==null){ - //创建新用户 String memberId = IdUtils.simpleUUID(); sysUser = new SysUser(); sysUser.setUserName(memberId); sysUser.setNickName("白金用户"); sysUser.setUserType("03"); - sysUser.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); + sysUser.setAvatar("https://jyzx-obs.obs.cn-sccd1.ctyun.cn/d41508d822cb4b7896aaa1bb56e6167f.png"); String password = "123456"; sysUser.setPassword(SecurityUtils.encryptPassword(password)); sysUser = sysUserService.registerUser(sysUser).getData(); @@ -261,7 +260,7 @@ member.setUserId(sysUser.getUserId()); member.setDelFlag(0); member.setNickname("白酒用户"); - member.setAvatar("https://hongruitang.oss-cn-beijing.aliyuncs.com/default.png"); + member.setAvatar("https://jyzx-obs.obs.cn-sccd1.ctyun.cn/d41508d822cb4b7896aaa1bb56e6167f.png"); member.setWxUnionid(unionid); member.setPhone(appMiniLoginDto.getPhone()); member.setMiniOpenid(openid); @@ -350,13 +349,13 @@ response.close(); httpClient.close(); } catch (IOException e) { - throw new RuntimeException(e); + throw new RuntimeException("姓名或者身份证号有误"); } } JSONObject jsonObject= JSON.parseObject(result); String object1= jsonObject.get("reason").toString(); if(!object1.equals("成功")){ - throw new ServiceException(object1); + throw new ServiceException("实名认证失败,姓名或者身份证号有误"); } @@ -519,6 +518,7 @@ .like(StringUtils.isNotBlank(query.getRealName()), Member::getRealName, query.getRealName()) .like(StringUtils.isNotBlank(query.getPhone()), Member::getPhone, query.getPhone()) + .eq(StringUtils.isNotBlank(query.getLevel()), Member::getLevel, query.getLevel()) .orderByDesc(Member::getCreateTime) .page(new Page<>(query.getPageCurr(), query.getPageSize())); if (StringUtils.isEmpty(page.getRecords())) { @@ -528,6 +528,7 @@ } @Override + @Transactional(propagation = Propagation.REQUIRES_NEW) public void updMembeOne(updMembeOneDTO dMembeOneDTO) { Member byId = this.getById(dMembeOneDTO.getMemberId()); if (dMembeOneDTO.getMoney()!=null){ @@ -543,39 +544,39 @@ Integer big=byId.getTotalPoints()+dMembeOneDTO.getTotalPoints(); byId.setTotalPoints(big); }else { - Integer big=byId.getTotalPoints()-dMembeOneDTO.getTotalPoints(); + Integer big = Math.max(byId.getTotalPoints() - dMembeOneDTO.getTotalPoints(), 0); byId.setTotalPoints(big); } } this.updateById(byId); LambdaQueryWrapper<MemberLevel> wrapper= Wrappers.lambdaQuery(); List<MemberLevel> list = memberLevelMapper.selectList(wrapper); - for (int i=0;i<list.size();i++){ - if (i==0){ - int ia = byId.getMoney().compareTo(list.get(0).getCumulativeConsumption()); - if (ia<0){ - byId.setLevel(0); - break; - } - } - if (i==list.size()-1){ - BigDecimal cumulative = list.get(i - 1).getCumulativeConsumption(); - BigDecimal cumulative1 = list.get(i).getCumulativeConsumption(); - if (cumulative.compareTo(byId.getMoney()) <= 0 && cumulative1.compareTo(byId.getMoney()) >= 0) { - byId.setLevel(list.get(i).getLevel()); - }else{ - byId.setLevel(list.get(i).getLevel()); - } - }else { - BigDecimal cumulative = list.get(i - 1).getCumulativeConsumption(); - BigDecimal cumulative1 = list.get(i).getCumulativeConsumption(); - if (cumulative.compareTo(byId.getMoney()) <= 0 && cumulative1.compareTo(byId.getMoney()) >= 0) { - byId.setLevel(list.get(i).getLevel()); - } + int appropriateLevel = findAppropriateLevel(list, byId.getMoney()); + byId.setLevel(appropriateLevel); + this.updateById(byId); + } + + + private static int findAppropriateLevel(List<MemberLevel> memberLevels, BigDecimal money) { + // 对于最开始的level,设置为0(假设0是最低等级) + int level = 0; + + for (int i = 0; i < memberLevels.size(); i++) { + MemberLevel currentLevel = memberLevels.get(i); + BigDecimal currentCumulativeConsumption = currentLevel.getCumulativeConsumption(); + + // 如果当前成员的消费额小于等于当前等级的累积消费额 + if (money.compareTo(currentCumulativeConsumption) < 0) { + return level; } + // 更新level为当前等级,准备下一次比较 + level = currentLevel.getLevel(); } + // 如果遍历完成后还没有返回,说明该成员的消费额高于所有已定义等级的累积消费额 + level = memberLevels.get(memberLevels.size() - 1).getLevel(); + return level; } /** @@ -628,6 +629,8 @@ .orderByDesc(Member::getLevel) .list(); } + + } -- Gitblit v1.7.1