From 437a74c950f626398edd13025c654286280e7bbc Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期一, 01 九月 2025 18:01:30 +0800
Subject: [PATCH] bug修改

---
 cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java |  363 +++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 262 insertions(+), 101 deletions(-)

diff --git a/cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java b/cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java
index b97525a..c8b23de 100644
--- a/cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java
+++ b/cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java
@@ -1,28 +1,36 @@
 package com.dsh.account.controller;
 
 
+import com.alibaba.fastjson.JSONObject;
 import com.dsh.account.entity.TAppUser;
+import com.dsh.account.feignclient.activity.model.IntegralCommodity;
 import com.dsh.account.feignclient.other.SysLogClient;
 import com.dsh.account.model.vo.userBenefitDetail.*;
 import com.dsh.account.service.RechargeRecordsService;
 import com.dsh.account.service.TAppUserService;
 import com.dsh.account.service.UserIntegralChangesService;
+import com.dsh.account.util.PayMoneyUtil;
 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.wechat.pay.contrib.apache.httpclient.util.AesUtil;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.PostMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.ResponseBody;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
 import org.springframework.web.multipart.MultipartFile;
 
 import javax.annotation.Resource;
 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.text.SimpleDateFormat;
 import java.util.List;
+import java.util.Map;
 
 /**
  * 使用福利 控制器
@@ -50,21 +58,46 @@
 
     private final SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd");
 
+    @Autowired
+    private PayMoneyUtil payMoneyUtil;
+    @Autowired
+    private TAppUserService appUserService;
+
 
     @ResponseBody
     @PostMapping("/api/useBenefit/indexOfAppUser")
-    @ApiOperation(value = "福利主页", tags = {"APP-使用福利"})
+    @ApiOperation(value = "福利主页【2.0】", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
+            @ApiImplicitParam(name = "lat", value = "经度", dataType = "string"),
+            @ApiImplicitParam(name = "lon", value = "纬度", dataType = "string")
     })
-    public ResultUtil<IndexOfUserBenefirVo> queryAppUserUser(){
+    public ResultUtil<IndexOfUserBenefirVo> queryAppUserUser(String lon, String lat) {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(tauService.queryBenefitDetails(appUserId));
-        }catch (Exception e){
+            IndexOfUserBenefirVo indexOfUserBenefirVo = tauService.queryBenefitDetails(appUserId, lon, lat);
+            List<IntegralCommodity> commodities = indexOfUserBenefirVo.getCommodities();
+            if (commodities.size() > 5) {
+                commodities = commodities.subList(0, 5);
+            }
+            indexOfUserBenefirVo.setCommodities(commodities);
+            TAppUser byId = appUserService.getById(appUserId);
+            if (byId.getIsVip()!=null && byId.getIsVip()==1){
+                SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
+                if (byId.getVipEndTime().getTime() > System.currentTimeMillis()) {
+                    indexOfUserBenefirVo.setVipEndTime(simpleDateFormat.format(byId.getVipEndTime()));
+                } else {
+                    indexOfUserBenefirVo.setVipEndTime("");
+                }
+            }else{
+                indexOfUserBenefirVo.setVipEndTime("");
+            }
+            return ResultUtil.success(indexOfUserBenefirVo);
+        } catch (Exception e) {
+            e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
@@ -75,26 +108,53 @@
     @ApiOperation(value = "用户个人信息", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
+            @ApiImplicitParam(name = "lat", value = "经度", dataType = "string"),
+            @ApiImplicitParam(name = "lon", value = "纬度", dataType = "string")
+
     })
-    public ResultUtil<AppUserDetailsVo> queryAppUserDetails(){
+    public ResultUtil<AppUserDetailsVo> queryAppUserDetails() {
         try {
             AppUserDetailsVo detailsVo = new AppUserDetailsVo();
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
             TAppUser tAppUser = tauService.getBaseMapper().selectById(appUserId);
-            if (null != tAppUser){
-                detailsVo.setUserImage(tAppUser.getHeadImg());
+            if (tAppUser.getCode() == null) {
+                detailsVo.setNeedChange(1);
+            } else {
+                detailsVo.setNeedChange(0);
+            }
+
+
+            if (null != tAppUser) {
+                detailsVo.setUserId(appUserId);
+                if (tAppUser.getHeadImg() != null) {
+                    detailsVo.setUserImage(tAppUser.getHeadImg());
+                } else {
+                    detailsVo.setUserImage("https://we-park-life.oss-cn-beijing.aliyuncs.com/img/630864764d3c4e98822ff976a2389559.jpg");
+                }
+
+
                 detailsVo.setUserName(tAppUser.getName());
                 detailsVo.setUserPhone(tAppUser.getPhone());
-                detailsVo.setSex(tAppUser.getGender() == 1 ? "男" : "女");
-                detailsVo.setBirthday(format1.format(tAppUser.getBirthday()));
-                detailsVo.setAddress(tAppUser.getProvince()+tAppUser.getCity());
-                detailsVo.setMemberLifespan(format1.format(tAppUser.getVipEndTime()));
+                detailsVo.setIsVip(tAppUser.getIsVip());
+                if (tAppUser.getGender() != null) {
+                    detailsVo.setSex(tAppUser.getGender() == 1 ? "男" : "女");
+                }
+                System.out.println("=============" + tAppUser);
+
+                if (tAppUser.getBirthday() != null) {
+                    detailsVo.setBirthday(format1.format(tAppUser.getBirthday()));
+                }
+                detailsVo.setAddress(tAppUser.getProvince() + tAppUser.getCity());
+                if (tAppUser.getVipEndTime() != null) {
+
+                    detailsVo.setMemberLifespan(format1.format(tAppUser.getVipEndTime()));
+                }
             }
             return ResultUtil.success(detailsVo);
-        }catch (Exception e){
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -105,20 +165,26 @@
     @ApiOperation(value = "上传用户头像", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
-            @ApiImplicitParam(name = "file",value = "图片字节",dataType = "MultipartFile")
+            @ApiImplicitParam(name = "userImage", value = "用户头像连接", dataType = "string")
     })
-    public ResultUtil uploadAppUserProfile(MultipartFile file, HttpServletRequest request){
+    public ResultUtil uploadAppUserProfile(String userImage) {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(tauService.uploadAppUserHeadImg(appUserId,file,request));
-        }catch (Exception e){
+            TAppUser byId = tauService.getById(appUserId);
+            if (ToolUtil.isNotEmpty(userImage)) {
+                byId.setHeadImg(userImage);
+                tauService.updateById(byId);
+            } else {
+                ResultUtil.error("头像不能为空!");
+            }
+            return ResultUtil.success();
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
-
 
 
     @ResponseBody
@@ -127,10 +193,10 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil cancellationAccount(){
+    public ResultUtil cancellationAccount() {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
 //            变更账号的状态为删除
@@ -140,11 +206,10 @@
 //            删除redis中用户key
             tokenUtil.logout();
             return ResultUtil.success();
-        }catch (Exception e){
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
-
 
 
     @ResponseBody
@@ -153,10 +218,10 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil logOutAccount(){
+    public ResultUtil logOutAccount() {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
             //            增加一条退出账号的日志
@@ -164,11 +229,10 @@
             //            删除redis中用户key
             tokenUtil.logout();
             return ResultUtil.success();
-        }catch (Exception e){
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
-
 
 
     @ResponseBody
@@ -177,16 +241,16 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
             @ApiImplicitParam(value = "年月", name = "yearMonth", required = true, dataType = "string"),
-            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = true, dataType = "int"),
+            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = false, dataType = "int"),
     })
-    public ResultUtil<List<ConsumeDetail>> getUserBillingDetails(String yearMonth,Integer recordId){
+    public ResultUtil<List<ConsumeDetail>> getUserBillingDetails(String yearMonth, Integer recordId) {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(tauService.queryUserBillingDetails(yearMonth,recordId,appUserId));
-        }catch (Exception e){
+            return ResultUtil.success(tauService.queryUserBillingDetails(yearMonth, recordId, appUserId));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -197,19 +261,19 @@
     @ApiOperation(value = "充值明细", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
-            @ApiImplicitParam(value = "年月", name = "yearMonth", required = true, dataType = "string"),
+            @ApiImplicitParam(value = "年月", name = "yearMonth", required = false, dataType = "string"),
             @ApiImplicitParam(value = "页码", name = "pageNum", required = true, dataType = "int"),
             @ApiImplicitParam(value = "每页数量", name = "pageSize", required = true, dataType = "int"),
-            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = true, dataType = "int"),
+            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = false, dataType = "int"),
     })
-    public ResultUtil<List<RechargesDetail>> wpGoldRechargeRecord(String yearMonth, Integer recordId,Integer pageNum,Integer pageSize){
+    public ResultUtil<List<RechargesDetail>> wpGoldRechargeRecord(String yearMonth, Integer recordId, Integer pageNum, Integer pageSize) {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(rechargeRService.getAppUserRechargeRecord(yearMonth,recordId,appUserId,pageNum,pageSize));
-        }catch (Exception e){
+            return ResultUtil.success(rechargeRService.getAppUserRechargeRecord(yearMonth, recordId, appUserId, pageNum, pageSize));
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
@@ -217,19 +281,19 @@
 
 
     @ResponseBody
-    @PostMapping("/base/useBenefit/voucherCenter")
+    @PostMapping("/api/useBenefit/voucherCenter")
     @ApiOperation(value = "充值中心", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil<List<RechargeCentVo>> rechargeCenterConfig(){
+    public ResultUtil<List<RechargeCentVo>> rechargeCenterConfig() {
         try {
             Integer appUserId = tokenUtil.getUserIdFormRedis();
-            if(null == appUserId){
+            if (null == appUserId) {
                 return ResultUtil.tokenErr();
             }
             return ResultUtil.success(tauService.getSysRechargeConfig(appUserId));
-        }catch (Exception e){
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -243,14 +307,14 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil rechargeCenPayment(RechargePayRequest request){
+    public ResultUtil rechargeCenPayment(RechargePayRequest request) {
         try {
             Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
+            if (null == userIdFormRedis) {
                 return ResultUtil.tokenErr();
             }
-            return rechargeRService.rechargeCenPayment(userIdFormRedis,request);
-        }catch (Exception e){
+            return rechargeRService.rechargeCenPayment(userIdFormRedis, request);
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
@@ -267,16 +331,8 @@
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
     })
-    public ResultUtil<PointMallDetailsResponse> pointsMallList(MallRequest request){
-        try {
-            Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
-                return ResultUtil.tokenErr();
-            }
-            return ResultUtil.success(tauService.queryAppUserIntegral(request,userIdFormRedis));
-        }catch (Exception e){
-            return ResultUtil.runErr();
-        }
+    public ResultUtil<List<Goods>> pointsMallList(MallRequest request) {
+        return ResultUtil.success(tauService.queryAppUserIntegral(request));
     }
 
 
@@ -291,14 +347,29 @@
             @ApiImplicitParam(value = "商品id", name = "goodId", required = true, dataType = "int"),
             @ApiImplicitParam(value = "商品类型 1实物 2课包 3门票 4优惠券", name = "goodsType", required = true, dataType = "int"),
     })
-    public ResultUtil<ProductDetailsVo> productDetails(Integer goodId, Integer goodsType){
+    public ResultUtil<ProductDetailsVo> productDetails(Integer goodId, Integer goodsType) {
         try {
-            return ResultUtil.success(tauService.productDetails(goodId,goodsType));
-        }catch (Exception e){
+            return ResultUtil.success(tauService.productDetails(goodId, goodsType));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
 
+
+    @ResponseBody
+    @PostMapping("/api/useBenefit/goodsDetailsOne")
+    @ApiOperation(value = "积分商城-商品详情", tags = {"APP-使用福利"})
+    @ApiImplicitParams({
+            @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
+            @ApiImplicitParam(value = "商品id", name = "goodId", required = true, dataType = "int"),
+    })
+    public ResultUtil<ProductDetailsVo> goodsDetailsOne(Integer goodId) {
+        try {
+            return ResultUtil.success(tauService.goodsDetailsOne(goodId));
+        } catch (Exception e) {
+            return ResultUtil.runErr();
+        }
+    }
 
 
     /**
@@ -314,14 +385,14 @@
             @ApiImplicitParam(value = "是否为课包商品(1=是 2=否)", name = "isCourse", required = true, dataType = "int"),
             @ApiImplicitParam(value = "商品id", name = "pointsMerId", required = true, dataType = "int"),
     })
-    public ResultUtil<StuAndStoreResponse> goodsOfCourseStore(String lat, String lon,Integer isCourse,Integer pointsMerId){
+    public ResultUtil<StuAndStoreResponse> goodsOfCourseStore(String lat, String lon, Integer isCourse, Integer pointsMerId) {
         try {
             Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
+            if (null == userIdFormRedis) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(tauService.queryAppUserDefaultStuAndStore(userIdFormRedis,pointsMerId,lat,lon,isCourse));
-        }catch (Exception e){
+            return ResultUtil.success(tauService.queryAppUserDefaultStuAndStore(userIdFormRedis, pointsMerId, lat, lon, isCourse));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -338,14 +409,13 @@
             @ApiImplicitParam(value = "商品类型 1实物 2课包 3门票 4优惠券", name = "goodsType", required = true, dataType = "String"),
             @ApiImplicitParam(value = "商品id", name = "pointsMerId", required = true, dataType = "int"),
     })
-    public ResultUtil<List<StoreResponse>> getExchangeStoreIds( Integer goodsType,Integer pointsMerId){
+    public ResultUtil<List<StoreResponse>> getExchangeStoreIds(Integer goodsType, Integer pointsMerId) {
         try {
-            return ResultUtil.success(tauService.queryStoresOfExchange(goodsType,pointsMerId));
-        }catch (Exception e){
+            return ResultUtil.success(tauService.queryStoresOfExchange(goodsType, pointsMerId));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
-
 
 
     /**
@@ -356,24 +426,112 @@
     @ApiOperation(value = "积分商城-商品兑换", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
-            @ApiImplicitParam(value = "商品id", name = "goodId", required = true, dataType = "int"),
-            @ApiImplicitParam(value = "商品类型 1实物 2课包 3门票 4优惠券", name = "goodsType", required = true, dataType = "int"),
-            @ApiImplicitParam(value = "兑换数量", name = "nums", required = false, dataType = "int"),
-            @ApiImplicitParam(value = "兑换方式(1=积分,2=积分+现金)", name = "exchangeType", required = true, dataType = "int"),
-            @ApiImplicitParam(value = "现金支付方式(1=微信 2=支付宝)", name = "payType", required = false, dataType = "int"),
-            @ApiImplicitParam(value = "学员id列表", name = "stuIds", required = false),
     })
-    public ResultUtil productRedemptionOperation(Integer goodId, Integer goodsType,Integer nums,Integer exchangeType,Integer payType,List<Integer> stuIds){
+    public ResultUtil productRedemptionOperation(GoodsExchangeVo exchangeType) {
         try {
             Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
+            if (null == userIdFormRedis) {
                 return ResultUtil.tokenErr();
             }
-            return tauService.productRedemptionOperation(userIdFormRedis,goodId,goodsType,nums,exchangeType,payType,stuIds);
-        }catch (Exception e){
+            return tauService.productRedemptionOperation(userIdFormRedis, exchangeType);
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
+
+
+    /**
+     * V3版本回调
+     * @param request
+     * @param response
+     */
+    @ResponseBody
+    @PostMapping("/base/coupon/weChatPaymentCouponCallback1")
+    public void weChatPaymentCouponCallback1(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 code = jsonInfo.getString("out_trade_no");
+            String trade_no = jsonInfo.getString("transaction_id");
+            String trade_state = jsonInfo.getString("trade_state");
+            if (trade_state.equals("SUCCESS")) {
+                ResultUtil resultUtil = tauService.paymentCouponCallback(code, trade_no);
+                if(resultUtil.getCode() == 200){
+                    PrintWriter out = response.getWriter();
+                    out.print("SUCCESS");
+                    out.flush();
+                    out.close();
+                }
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+    @ResponseBody
+    @PostMapping("/base/coupon/weChatPaymentCouponCallback")
+    public void weChatPaymentCouponCallback(HttpServletRequest request, HttpServletResponse response){
+        try {
+            Map<String, String> map = payMoneyUtil.weixinpayCallback(request);
+            if(null != map){
+                String code = map.get("out_trade_no");
+                String trade_no = map.get("transaction_id");
+                String result = map.get("result");
+                ResultUtil resultUtil = tauService.paymentCouponCallback(code, trade_no);
+                if(resultUtil.getCode() == 200){
+                    PrintWriter out = response.getWriter();
+                    out.print(result);
+                    out.flush();
+                    out.close();
+                }
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+    @ResponseBody
+    @PostMapping("/base/coupon/aliPaymentCouponCallback")
+    public void aliPaymentCouponCallback(HttpServletRequest request, HttpServletResponse response){
+        try {
+            Map<String, String> map = payMoneyUtil.alipayCallback(request);
+            if(null != map){
+                String code = map.get("out_trade_no");
+                String trade_no = map.get("trade_no");
+                ResultUtil resultUtil = tauService.paymentCouponCallback(code, trade_no);
+                if(resultUtil.getCode() == 200){
+                    PrintWriter out = response.getWriter();
+                    out.print("success");
+                    out.flush();
+                    out.close();
+                }
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+
+
+
+
 
 
     /**
@@ -384,17 +542,17 @@
     @ApiOperation(value = "积分商城-积分明细", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
-            @ApiImplicitParam(value = "年月", name = "yearMonth", required = true, dataType = "string"),
-            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = true, dataType = "int"),
+            @ApiImplicitParam(value = "年月", name = "yearMonth", required = false, dataType = "string"),
+            @ApiImplicitParam(value = "记录(1充值 2扣除)", name = "recordId", required = false, dataType = "int"),
     })
-    public ResultUtil<IntegralDetailsResponse> pointDetails(String yearMonth, Integer recordId){
+    public ResultUtil<List<IntegralsData>> pointDetails(String yearMonth, Integer recordId) {
         try {
             Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
+            if (null == userIdFormRedis) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(uicService.queryUserPointsDetails(yearMonth,recordId,userIdFormRedis));
-        }catch (Exception e){
+            return ResultUtil.success(uicService.queryUserPointsDetails(yearMonth, recordId, userIdFormRedis));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -408,17 +566,23 @@
     @ApiOperation(value = "积分商城-兑换记录", tags = {"APP-使用福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
-            @ApiImplicitParam(value = "使用状态 (1已使用 2未使用)", name = "useType", required = true, dataType = "string"),
-            @ApiImplicitParam(value = "商品类型  1实物 2课包 3门票 4优惠券", name = "goodType", required = true, dataType = "int"),
+            @ApiImplicitParam(value = "使用状态 (1已使用 2未使用)", name = "useType", required = false, dataType = "string"),
+            @ApiImplicitParam(value = "商品类型  1实物 2课包 3门票 4优惠券", name = "goodType", required = false, dataType = "int"),
+            @ApiImplicitParam(value = "page", name = "页数", required = true, dataType = "int"),
+            @ApiImplicitParam(value = "size", name = "size", required = true, dataType = "int"),
     })
-    public ResultUtil<List<ExchangeDetailsResponse>> exchangeRecordsDetails(Integer useType, Integer goodType){
+    public ResultUtil<List<ExchangeDetailsResponse>> exchangeRecordsDetails(Integer useType, Integer goodType, Integer page, Integer size) {
         try {
+            if (page == null || size == null) {
+                page = 1;
+                size = 10;
+            }
             Integer userIdFormRedis = tokenUtil.getUserIdFormRedis();
-            if(null == userIdFormRedis){
+            if (null == userIdFormRedis) {
                 return ResultUtil.tokenErr();
             }
-            return ResultUtil.success(uicService.queryExchangeGoodsdetails(userIdFormRedis,useType,goodType));
-        }catch (Exception e){
+            return ResultUtil.success(uicService.queryExchangeGoodsdetails1(userIdFormRedis, useType, goodType, page, size));
+        } catch (Exception e) {
             return ResultUtil.runErr();
         }
     }
@@ -434,14 +598,11 @@
             @ApiImplicitParam(name = "Authorization", value = "Bearer +token", required = true, dataType = "String", paramType = "header", defaultValue = "Bearer eyJhbGciOiJIUzUxMiJ9....."),
             @ApiImplicitParam(value = "记录id", name = "detailsId", required = true, dataType = "string"),
     })
-    public ResultUtil<PointDetailsVo> redemptionDetails(Integer detailsId){
-        try {
-            return ResultUtil.success(uicService.queryRedemptionDetails(detailsId));
-        }catch (Exception e){
-            return ResultUtil.runErr();
-        }
+    public ResultUtil<PointDetailsVo> redemptionDetails(Long detailsId) {
+        PointDetailsVo pointDetailsVo = uicService.queryRedemptionDetails(detailsId);
+        pointDetailsVo.getPics().remove(0);
+        return ResultUtil.success(pointDetailsVo);
     }
-
 
 
 }

--
Gitblit v1.7.1