From 324ed9fac852bc4117ee0da65a586adef258bd52 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期一, 01 九月 2025 11:08:59 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/WXCallBackController.java |  119 +++++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 91 insertions(+), 28 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/WXCallBackController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/WXCallBackController.java
index 8b3dbc9..30dafc9 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/WXCallBackController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/WXCallBackController.java
@@ -1,5 +1,6 @@
 package com.ruoyi.other.controller;
 
+import com.alibaba.fastjson.JSONObject;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.service.TokenService;
@@ -26,11 +27,14 @@
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
+import java.io.BufferedReader;
 import java.io.IOException;
 import java.io.PrintWriter;
+import java.net.URLDecoder;
 import java.text.SimpleDateFormat;
 import java.time.LocalDateTime;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.Map;
 
 /**
@@ -63,38 +67,47 @@
 
     @ResponseBody
     @PostMapping("/integralCallback")
-    public R integralCallback(HttpServletRequest request, String r2_OrderNo) {
-//        System.err.println("积分充值回调");
-//        PayResult payResult= null;
-//        try {
-//            payResult = wechatPayService.processNotify(request);
-//        } catch (Exception e) {
-//            throw new RuntimeException(e);
-//        }
-        System.err.println("======积分充值回调");
-        System.err.println("======积分充值回调单号" + r2_OrderNo);
-        System.err.println("请求" + request.getParameterMap());
-        Map<String, String[]> parameterMap = request.getParameterMap();
-        String r6Status = request.getParameter("r6_Status");
-        if (org.springframework.util.StringUtils.hasLength(r6Status)) {
-            if (r6Status.equals("101")) {
-                return R.fail("支付失败");
+    public R integralCallback(HttpServletRequest request) throws IOException {
+        System.err.println("积分充值回调");
+        Map<String, String> params = new HashMap<String, String>();
+        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);
+        // URL解码
+        String decodedBody = URLDecoder.decode(requestBody.toString(), "UTF-8");
+        System.err.println("解码后请求体: " + decodedBody);
+        String[] paramsArray = decodedBody.split("&");
+        String respDataJson = "";
+        for (String param : paramsArray) {
+            if (param.startsWith("resp_data=")) {
+                respDataJson = param.substring(10); // 去掉"resp_data="前缀
+                break;
             }
         }
-        // 循环打印
-        for (Map.Entry<String, String[]> entry : parameterMap.entrySet()) {
-            String key = entry.getKey();
-            String[] values = entry.getValue();
-            for (String value : values) {
-                System.err.println("======回调开始" + key + ":" + value);
-            }
+        System.err.println("处理后的"+respDataJson);
+        // 转换为JSONObject
+        JSONObject resp_data = JSONObject.parseObject(respDataJson);
+        System.err.println(resp_data);
+        String string = resp_data.getString("trans_stat");
+        if (!string.equals("S")){
+            System.err.println("陈工");
         }
-        IntegralPay integralPay = integralPayService.lambdaQuery().eq(IntegralPay::getCode, r2_OrderNo).one();
+        String req_seq_id = resp_data.getString("req_seq_id");
+        String hf_seq_id = resp_data.getString("hf_seq_id");
+        IntegralPay integralPay = integralPayService.lambdaQuery().eq(IntegralPay::getCode, req_seq_id).one();
         if (integralPay != null && integralPay.getPayStatus() == 1) {
+
             SysUser data = sysUserClient.getSysUser(integralPay.getUserId()).getData();
             integralPay.setPayStatus(2);
             integralPay.setPayTime(LocalDateTime.now());
-//            integralPay.setOrderNumber(payResult.getTransactionId());
+            integralPay.setOrderNumber(hf_seq_id);
             integralPayService.updateById(integralPay);
             IntegralRecord integralRecord = new IntegralRecord();
             integralRecord.setPayId(integralPay.getId());
@@ -104,15 +117,65 @@
             integralRecord.setIntegralCount(integralPay.getIntegralCount());
             integralRecord.setDelFlag(0);
             integralRecord.setCreateTime(LocalDateTime.now());
-            integralRecordService.save(integralRecord);
-            data.setIntegral(data.getIntegral() + integralPay.getIntegralCount());
+            if (integralPay.getIntegralCount()>0){
+                integralRecordService.save(integralRecord);
+            }
+            data.setIntegral(data.getIntegral()!=null?data.getIntegral() + integralPay.getIntegralCount():integralPay.getIntegralCount());
             sysUserClient.updateSysUser(data);
             return R.ok(null, "success");
         }
         return R.ok(null, "error");
-
     }
 
+    public static void main(String[] args) {
+        String s = "resp_desc=交易成功[000]&resp_code=00000000&sign=PymKvUt5iBSn1EmBHu41ESxygYl80rHVRZVFlmipqg5zYSF/Yeq30ZJm0l5ztvIaGvUQChYQ5DAVkN/N+TYg1WU+FhMi/RTP15OpBAj8gGtYPyk7Z4lF9FLwiSGmX0RvCYWI5+LVsk10i7+j9332kAuB5GpKm0tOaDGULHZYlfrt5D5BgJ8RKdjYJ4OOV1Ex5J5PNLPYE5uc8rdzTQ9HHTu4N+sBOBV+tXJFYtSOoAaiDsRmv5Er8X8ogSlNODmaj7zBbZQHrPTTs8rtBl+YbQo28cmgykwdl9pPTMtAjkL9dX6/JVApquKgm9M+v8+CDT0MKjn/nyVE4J2EWc/7LQ==&" +
+                "resp_data={\"acct_date\":\"20250816\",\"acct_id\":\"F10004674\",\"acct_split_bunch\":{\"acct_infos\":[{\"acct_date\":\"20250816\",\"acct_id\":\"F10004674\",\"div_amt\":\"0.01\",\"huifu_id\":\"6666000174575407\"}],\"fee_acct_date\":\"20250816\",\"fee_acct_id\":\"F10004674\",\"fee_amt\":\"0.00\",\"fee_huifu_id\":\"6666000174575407\"},\"acct_stat\":\"S\",\"atu_sub_mer_id\":\"797542530\",\"avoid_sms_flag\":\"\",\"bagent_id\":\"6666000167477678\",\"bank_desc\":\"支付成功\",\"bank_message\":\"支付成功\",\"bank_order_no\":\"4200002762202508169050647775\"" +
+                ",\"bank_seq_id\":\"273346\",\"bank_type\":\"OTHERS\",\"base_acct_id\":\"F10004674\"," +
+                "\"batch_id\":\"250816\",\"channel_type\":\"N\",\"charge_flags\":\"758_0\",\"debit_type\"" +
+                ":\"0\",\"delay_acct_flag\":\"N\",\"div_flag\":\"0\",\"end_time\":\"20250816153144\"," +
+                "\"fee_amount\":\"0.00\",\"fee_amt\":\"0.00\",\"fee_flag\":2,\"fee_formula_infos\"" +
+                ":[{\"fee_formula\":\"MAX(0.00,AMT*0.005)\",\"fee_type\":\"TRANS_FEE\"}],\"fee_rec_type" +
+                "\":\"1\",\"fee_type\":\"INNER\",\"gate_id\":\"IB\",\"hf_seq_id\":\"002900TOP1B250816153133P665ac139cd300000\"" +
+                ",\"huifu_id\":\"6666000174575407\",\"is_delay_acct\":\"0\",\"is_div\":\"0\",\"maze_resp_code\":\"\",\"mer_nam" +
+                "e\":\"贵州中嘉瑞祺新能源科技有限公司\",\"mer_ord_id\":\"2025081615313312273346\",\"mypaytsf_discount\":\"0.00\",\"" +
+                "need_big_object\":false,\"notify_type\":2,\"org_auth_no\":\"\",\"org_huifu_seq_id\":\"\",\"org_t" +
+                "rans_date\":\"\",\"out_ord_id\":\"4200002762202508169050647775\",\"out_trans_id\":\"42" +
+                "00002762202508169050647775\",\"party_order_id\":\"032425081655893847103301\",\"pay" +
+                "_amt\":\"0.01\",\"pay_scene\":\"02\",\"posp_seq_id\":\"032425081655893847103301\"" +
+                ",\"product_id\":\"KAZX\",\"ref_no\":\"153133273346\",\"req_date\":\"202508" +
+                "16\",\"req_seq_id\":\"2025081615313312273346\",\"resp_code\":\"00000000" +
+                "\",\"resp_desc\":\"交易成功\",\"risk_check_data\":{},\"risk_check_info\":{" +
+                "},\"settlement_amt\":\"0.01\",\"sub_resp_code\":\"00000000\",\"sub_resp_desc\"" +
+                ":\"交易成功\",\"subsidy_stat\":\"I\",\"sys_id\":\"6666000174575407\",\"" +
+                "trade_type\":\"T_MINIAPP\",\"trans_amt\":\"0.01\",\"trans_date\":\"2025081" +
+                "6\",\"trans_fee_allowance_info\":{\"actual_fee_amt\":\"0.00\",\"allowance_fee_" +
+                "amt\":\"0.00\",\"allowance_type\":\"0\",\"receivable_fee_amt\":\"0.00\"},\"trans_s" +
+                "tat\":\"S\",\"trans_time\":\"153133\",\"trans_type\":\"T_MINIAPP\",\"ts_encash_detail\":[" +
+                "],\"wx_response\":{\"bank_type\":\"OTHERS\",\"coupon_fee\":\"0.00\",\"openid\":\"o8jhot3gj5UeqqT" +
+                "-od35bM6rJOYk\",\"sub_appid\":\"wx049faf9c5234f31c\",\"sub_openid\":\"oJiKr7Rm5v3qGzOSy5WQp8_qrvic\"}}";
+
+        // 解析参数
+        String[] paramsArray = s.split("&");
+        String respDataJson = "";
+        for (String param : paramsArray) {
+            if (param.startsWith("resp_data=")) {
+                respDataJson = param.substring(10); // 去掉"resp_data="前缀
+                break;
+            }
+        }
+
+        // 转换为JSONObject
+        JSONObject resp_data = JSONObject.parseObject(respDataJson);
+        System.err.println(resp_data);
+        String string = resp_data.getString("trans_stat");
+        if (!string.equals("S")){
+            System.err.println("陈工");
+        }
+        String req_seq_id = resp_data.getString("req_seq_id");
+        String hf_seq_id = resp_data.getString("hf_seq_id");
+        System.err.println(req_seq_id);
+        System.err.println(hf_seq_id);
+    }
     @ResponseBody
     @PostMapping("/serviceCallback")
     public void serviceCallback(HttpServletRequest request, HttpServletResponse response) {

--
Gitblit v1.7.1