From b1a6188c6b3d3454d32440c555e41402739afbc9 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 24 十月 2025 18:16:26 +0800
Subject: [PATCH] bug修改,后台新增修改用户积分

---
 cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java |  186 ++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 160 insertions(+), 26 deletions(-)

diff --git a/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java b/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java
index 4d9fe63..94baaba 100644
--- a/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java
+++ b/cloud-server-account/src/main/java/com/dsh/account/controller/AppUserController.java
@@ -1,17 +1,12 @@
 package com.dsh.account.controller;
 
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.dsh.account.dto.BindDto;
-import com.dsh.account.dto.IntroduceUserQuery;
-import com.dsh.account.dto.SelectDto;
-import com.dsh.account.dto.UpdateInfoDto;
-import com.dsh.account.entity.IntroduceUser;
-import com.dsh.account.entity.TAppGift;
-import com.dsh.account.entity.TAppUser;
-import com.dsh.account.entity.TCourseInfoRecord;
-import com.dsh.account.entity.TStudent;
-import com.dsh.account.entity.UserIntegralChanges;
+import com.baomidou.mybatisplus.extension.api.R;
+import com.dsh.account.dto.*;
+import com.dsh.account.entity.*;
+import com.dsh.account.feignclient.other.VipClient;
 import com.dsh.account.model.AddAppUserVo;
 import com.dsh.account.model.AdvertisementChangeStateDTO;
 import com.dsh.account.model.AppUserByNameAndPhoneDTO;
@@ -20,6 +15,7 @@
 import com.dsh.account.model.LoginSMSCodeVo;
 import com.dsh.account.model.LoginWeChatVo;
 import com.dsh.account.model.QueryByNamePhone;
+import com.dsh.account.model.query.UserDetailsOfSearch;
 import com.dsh.account.model.query.appUserQuery.QueryAppUser;
 import com.dsh.account.model.vo.QueryAppUserVO;
 import com.dsh.account.service.IVipPaymentService;
@@ -32,9 +28,13 @@
 import com.dsh.account.util.ResultUtil;
 import com.dsh.account.util.TokenUtil;
 import com.dsh.account.util.ToolUtil;
+import com.dsh.account.util.wx.WxV3PayConfig;
+import com.dsh.account.vo.VipPaymentVO;
+import com.wechat.pay.contrib.apache.httpclient.util.AesUtil;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import org.checkerframework.checker.guieffect.qual.UI;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PathVariable;
@@ -46,7 +46,9 @@
 
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
+import java.io.BufferedReader;
 import java.io.PrintWriter;
+import java.nio.charset.StandardCharsets;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
@@ -63,6 +65,8 @@
 
     @Autowired
     private TAppUserService appUserService;
+    @Autowired
+    private VipClient vipClient;
 
     @Autowired
     private PayMoneyUtil payMoneyUtil;
@@ -78,6 +82,9 @@
 
     @Autowired
     private TAppGiftService appGiftService;
+
+    @Autowired
+    private UserIntegralChangesService userIntegralChangesService;
 
     /**
      * 根据介绍有礼id查询当前活动参与次数
@@ -199,7 +206,7 @@
     @GetMapping("/base/appUser/getAppUserByPhone/{phone}")
     public TAppUser getAppUserByPhone(@PathVariable("phone") String phone) {
         TAppUser appUser = appUserService.getOne(new QueryWrapper<TAppUser>().eq("phone", phone)
-                .eq("state",1));
+                .eq("state", 1));
         return appUser;
     }
 
@@ -291,7 +298,6 @@
     @ResponseBody
     @PostMapping("/base/appUser/loginSMSCode")
     @ApiOperation(value = "短信验证码登录", tags = {"APP-登录注册"})
-
     public ResultUtil<String> loginSMSCode(LoginSMSCodeVo loginSMSCodeVo) {
         try {
             return appUserService.loginSMSCode(loginSMSCodeVo);
@@ -433,9 +439,10 @@
     @ApiOperation(value = "购买年度会员", tags = {"APP-成为会员"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "支付方式(1=微信,2=支付宝)", name = "payType", dataType = "int", required = true),
+            @ApiImplicitParam(value = "会员卡id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
     })
-    public ResultUtil addVipPayment(Integer payType) {
+    public ResultUtil addVipPayment(Integer payType, Integer id) {
         if (ToolUtil.isEmpty(payType)) {
             return ResultUtil.paranErr("payType");
         }
@@ -444,13 +451,96 @@
             if (null == uid) {
                 return ResultUtil.tokenErr();
             }
-            return vipPaymentService.addVipPayment(uid, payType);
+            return vipPaymentService.addVipPayment(uid, payType, id);
         } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
 
+    @ResponseBody
+    @PostMapping("/api/appUser/vipPayment")
+    @ApiOperation(value = "页面数据展示", tags = {"APP-成为会员"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "Authorization", value = "用户token(Bearer +token)", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9.....")
+    })
+    public ResultUtil<VipPaymentVO> vipPayment() {
+
+        try {
+            Integer uid = tokenUtil.getUserIdFormRedis();
+            if (null == uid) {
+                return ResultUtil.tokenErr();
+            }
+            TAppUser appUser = appUserService.getById(uid);
+            VipPaymentVO res = new VipPaymentVO();
+            res.setHeadImg(appUser.getHeadImg());
+            res.setName(appUser.getName());
+            res.setVipEndTime(appUser.getVipEndTime());
+            if (appUser.getVipEndTime() == null) {
+                res.setIsVip(0);
+            } else if (appUser.getVipEndTime().before(new Date())) {
+                res.setIsVip(0);
+            } else {
+                res.setIsVip(1);
+            }
+            appUserService.updateById(appUser);
+            List<Vip> vips = vipClient.listAll();
+            res.setVipList(vips);
+
+            return ResultUtil.success(res);
+
+        } catch (Exception e) {
+            e.printStackTrace();
+            return ResultUtil.runErr();
+        }
+    }
+
+//
+//    /**
+//     * 购买年度会员支付微信回调V3版本回调
+//     *
+//     * @param request
+//     * @param response
+//     */
+//    @ResponseBody
+//    @PostMapping("/base/appUser/addVipPaymentWeChatCallback1")
+//    public void addVipPaymentWeChatCallback1(HttpServletRequest request, HttpServletResponse response) {
+//        try {
+//            System.err.println("微信回调");
+//            System.err.println("请求" + request);
+//            BufferedReader reader = request.getReader();
+//            String string1 = reader.toString();
+//            System.err.println("请求reader" + string1);
+//            StringBuilder requestBody = new StringBuilder();
+//            String line;
+//            while ((line = reader.readLine()) != null) {
+//                requestBody.append(line);
+//            }
+//            System.err.println("全部请求体" + requestBody);
+//            JSONObject jsonObject = JSONObject.parseObject(requestBody.toString());
+//            JSONObject resource = jsonObject.getJSONObject("resource");
+//
+//            AesUtil aesUtil = new AesUtil(WxV3PayConfig.apiV3Key.getBytes(StandardCharsets.UTF_8));
+//            String decryptedData = aesUtil.decryptToString(resource.getString("associated_data").getBytes(StandardCharsets.UTF_8), resource.getString("nonce").getBytes(StandardCharsets.UTF_8),
+//                    resource.getString("ciphertext"));
+//            System.err.println("微信解密的字符串信息" + decryptedData);
+//            JSONObject jsonInfo = (JSONObject) JSONObject.parse(decryptedData);
+//            String out_trade_no = jsonInfo.getString("out_trade_no");
+//            String transaction_id = jsonInfo.getString("transaction_id");
+//            String trade_state = jsonInfo.getString("trade_state");
+//            if (trade_state.equals("SUCCESS")) {
+//                ResultUtil resultUtil = vipPaymentService.addVipPaymentCallback(out_trade_no, transaction_id);
+//                if (resultUtil.getCode() == 200) {
+//                    PrintWriter out = response.getWriter();
+//                    out.write("SUCCESS");
+//                    out.flush();
+//                    out.close();
+//                }
+//            }
+//        } catch (Exception e) {
+//            e.printStackTrace();
+//        }
+//    }
 
     /**
      * 购买年度会员支付微信回调
@@ -479,7 +569,6 @@
             e.printStackTrace();
         }
     }
-
 
     /**
      * 购买年度会员支付支付宝回调
@@ -527,6 +616,7 @@
             return null;
         }
     }
+
     /**
      * 根据用户id获取用户信息
      *
@@ -535,12 +625,10 @@
      */
     @ResponseBody
     @PostMapping("/base/appUser/queryAppUserBatch")
-    List<TAppUser> queryAppUserBatch(@RequestBody List<Integer> appUserIdList){
+    List<TAppUser> queryAppUserBatch(@RequestBody List<Integer> appUserIdList) {
         return appUserService.listByIds(appUserIdList);
     }
 
-    @Autowired
-    private UserIntegralChangesService userIntegralChangesService;
 
     /**
      * 修改用户信息
@@ -553,7 +641,7 @@
         try {
             TAppUser appUser1 = appUserService.getById(appUser.getId());
             appUserService.updateById(appUser);
-            if(appUser.getIntegral().compareTo(appUser1.getIntegral()) != 0){
+            if (appUser.getIntegral().compareTo(appUser1.getIntegral()) != 0) {
                 UserIntegralChanges userIntegralChanges = new UserIntegralChanges();
                 userIntegralChanges.setAppUserId(appUser.getId());
                 userIntegralChanges.setOldIntegral(appUser1.getIntegral());
@@ -599,6 +687,33 @@
         }
     }
 
+    @PostMapping("/base/appUser/updateIntegral")
+    public Boolean updateIntegral(@RequestBody UpdateIntegral updateIntegral) {
+        TAppUser appUser = appUserService.getById(updateIntegral.getId());
+        Integer integral = appUser.getIntegral();
+        switch (updateIntegral.getChangeType()) {
+            case 1:
+                integral = integral + updateIntegral.getIntegral();
+                break;
+            case 2:
+                integral = integral - updateIntegral.getIntegral();
+                break;
+        }
+
+        UserIntegralChanges userIntegralChanges = new UserIntegralChanges();
+        userIntegralChanges.setAppUserId(updateIntegral.getId());
+        userIntegralChanges.setType(1);
+        userIntegralChanges.setOldIntegral(appUser.getIntegral());
+        userIntegralChanges.setNewIntegral(integral);
+        userIntegralChanges.setRemark(updateIntegral.getRemark());
+        userIntegralChanges.setInsertTime(new Date());
+        userIntegralChanges.setCategory(updateIntegral.getChangeType());
+        userIntegralChangesService.save(userIntegralChanges);
+        appUser.setIntegral(integral);
+        appUserService.updateById(appUser);
+        return true;
+    }
+
     @PostMapping("/base/appUser/queryById")
     public TAppUser queryById(@RequestBody Integer appUserId) {
         try {
@@ -638,7 +753,7 @@
 
 
     @PostMapping("/appUser/queryAppUserByCityCode")
-    public List<TAppUser> queryAppUserByCityCode(@RequestBody String cityCode){
+    public List<TAppUser> queryAppUserByCityCode(@RequestBody String cityCode) {
         return appUserService.list(new QueryWrapper<TAppUser>()
                 .eq("state", 1)
                 .eq("cityCode", cityCode)
@@ -646,14 +761,14 @@
     }
 
 
-
     /**
      * 根据城市code获取用户的id集合
+     *
      * @param cityCode 城市code
      * @return
      */
-    @PostMapping("/appUser/getAppUserIds")
-    public List<Integer> getAppUserIds(@RequestBody String cityCode){
+    @GetMapping("/appUser/getAppUserIds/{cityCode}")
+    public List<Integer> getAppUserIds(@PathVariable("cityCode") String cityCode) {
         List<TAppUser> list = appUserService.list(new QueryWrapper<TAppUser>().eq("cityCode", cityCode).eq("state", 1));
         return list.stream().map(TAppUser::getId).collect(Collectors.toList());
     }
@@ -661,19 +776,38 @@
 
     /**
      * 根据省市名称所有用户
+     *
      * @param appUserIdsByCityName
      * @return
      */
     @PostMapping("/appUser/getAppUserIdsByCityName")
-    public List<Integer> getAppUserIdsByCityName(@RequestBody AppUserIdsByCityName appUserIdsByCityName){
+    public List<Integer> getAppUserIdsByCityName(@RequestBody AppUserIdsByCityName appUserIdsByCityName) {
         QueryWrapper<TAppUser> queryWrapper = new QueryWrapper<TAppUser>().eq("state", 1);
-        if(ToolUtil.isNotEmpty(appUserIdsByCityName.getProvince())){
+        if (ToolUtil.isNotEmpty(appUserIdsByCityName.getProvince())) {
             queryWrapper.like("province", appUserIdsByCityName.getProvince());
         }
-        if(ToolUtil.isNotEmpty(appUserIdsByCityName.getCity())){
+        if (ToolUtil.isNotEmpty(appUserIdsByCityName.getCity())) {
             queryWrapper.like("city", appUserIdsByCityName.getCity());
         }
         List<TAppUser> list = appUserService.list(queryWrapper);
         return list.stream().map(TAppUser::getId).collect(Collectors.toList());
     }
+
+
+    @PostMapping("/appUser/queryAppUserByIds")
+    @ResponseBody
+    public List<TStudent> queryAppUserByIds(@RequestBody UserDetailsOfSearch search) {
+        LambdaQueryWrapper<TStudent> tAppUserLambdaQueryWrapper = new LambdaQueryWrapper<>();
+        if (ToolUtil.isNotEmpty(search.getIdCard())) {
+            tAppUserLambdaQueryWrapper.eq(TStudent::getIdCard, search.getIdCard());
+        }
+        if (ToolUtil.isNotEmpty(search.getPhone())) {
+            tAppUserLambdaQueryWrapper.eq(TStudent::getPhone, search.getPhone());
+        }
+        if (ToolUtil.isNotEmpty(search.getName())) {
+            tAppUserLambdaQueryWrapper.eq(TStudent::getName, search.getName());
+        }
+        tAppUserLambdaQueryWrapper.in(TStudent::getId, search.getUseIds());
+        return studentService.list(tAppUserLambdaQueryWrapper);
+    }
 }

--
Gitblit v1.7.1