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