From 4c9035836c18886883d3f69d8443c53d15b068fc Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期五, 22 八月 2025 14:39:53 +0800 Subject: [PATCH] 会员支付相关 --- cloud-server-account/src/main/java/com/dsh/account/controller/UseBenefitsController.java | 61 +++++++++++++++++++++++++++++- 1 files changed, 59 insertions(+), 2 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 88665d2..f22844f 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,6 +1,7 @@ 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; @@ -12,6 +13,8 @@ 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; @@ -22,7 +25,9 @@ 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; @@ -55,6 +60,8 @@ @Autowired private PayMoneyUtil payMoneyUtil; + @Autowired + private TAppUserService appUserService; @ResponseBody @@ -77,6 +84,15 @@ 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(""); + } + } return ResultUtil.success(indexOfUserBenefirVo); } catch (Exception e) { e.printStackTrace(); @@ -422,7 +438,50 @@ } + /** + * 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") @@ -445,8 +504,6 @@ e.printStackTrace(); } } - - @ResponseBody @PostMapping("/base/coupon/aliPaymentCouponCallback") -- Gitblit v1.7.1