From 03ee24e370a02b6d4bbce2634821b31fa056fce8 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期二, 16 五月 2023 10:22:51 +0800
Subject: [PATCH] 修改日志存储

---
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IDivisionRecordService.java                 |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceRequest.java           |  176 +++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/AgentMapper.java                                |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/PlatformRechargeRecordMapper.java               |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/DivisionRecordServiceImpl.java         |   15 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PamentOrderUser.java            |   46 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Agent.java                                    |  105 ++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/RechargeRecord.java                           |    5 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSASignature.java                |  118 ++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/DivisionRecord.java                           |   73 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/YouTuiDriver.java                             |    2 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DriverMapper.xml                        |    4 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AgentServiceImpl.java                  |   15 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/PlatformRechargeRecordServiceImpl.java |   15 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Receive.java                    |  102 ++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IPlatformRechargeRecordService.java         |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSAEncryptGeneration.java        |   65 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/CacheUtils.java                  |   39 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/OrderServiceImpl.java                  |  392 ++++++-
 user/guns-admin/src/main/resources/application.yml                                                                         |   31 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveGood.java                |   48 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DivisionRecordMapper.xml                |   19 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Complete.java                   |   58 +
 user/guns-admin/pom.xml                                                                                                    |    6 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceResponse.java          |  121 ++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/TrhRequest.java                  |   31 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/DivisionRecordMapper.java                       |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Driver.java                                   |   20 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/AgentMapper.xml                         |   21 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveUser.java                |   27 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/PlatformRechargeRecordMapper.xml        |   16 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/StringUtil.java                  |   23 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/OrderMapper.xml                         |    2 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/config/ChannelConfig.java             |   60 +
 user/guns-admin/src/main/resources/redis.properties                                                                        |   22 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AppUserServiceImpl.java                |   52 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/PlatformRechargeRecord.java                   |   58 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IAgentService.java                          |   11 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrderGood.java           |   48 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrder.java               |  293 ++++++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Transfer.java                    |   76 +
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/OrderController.java                                   |  144 ++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Order.java                                    |    5 
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Base64.java                      |  288 ++++++
 user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/AppUserController.java                                 |   47 
 45 files changed, 2,628 insertions(+), 126 deletions(-)

diff --git a/user/guns-admin/pom.xml b/user/guns-admin/pom.xml
index 9127482..4d63379 100644
--- a/user/guns-admin/pom.xml
+++ b/user/guns-admin/pom.xml
@@ -198,6 +198,12 @@
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-starter-data-mongodb</artifactId>
         </dependency>
+        <dependency>
+            <groupId>cn.hutool</groupId>
+            <artifactId>hutool-all</artifactId>
+            <version>5.7.7</version>
+        </dependency>
+
     </dependencies>
 
     <build>
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/AppUserController.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/AppUserController.java
index facf287..3fcf80f 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/AppUserController.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/AppUserController.java
@@ -8,6 +8,8 @@
 import com.supersavedriving.user.modular.system.model.AppUser;
 import com.supersavedriving.user.modular.system.model.SystemConfig;
 import com.supersavedriving.user.modular.system.service.*;
+import com.supersavedriving.user.modular.system.util.MallBook.model.InterfaceResponse;
+import com.supersavedriving.user.modular.system.util.MallBook.util.RSASignature;
 import com.supersavedriving.user.modular.system.util.PayMoneyUtil;
 import com.supersavedriving.user.modular.system.util.RedisUtil;
 import com.supersavedriving.user.modular.system.util.ResultUtil;
@@ -314,18 +316,47 @@
 //    @ServiceLog(name = "余额充值回调", url = "/base/appUser/rechargeBalanceCallback")
     public void rechargeBalanceCallback(HttpServletRequest request, HttpServletResponse response){
         try {
-            Map<String, String> map = payMoneyUtil.weixinpayCallback(request);
-            if(null != map){
-                String out_trade_no = map.get("out_trade_no");
-                String transaction_id = map.get("transaction_id");
-                String result = map.get("result");
-                String orderId = out_trade_no.substring(17);
-                appUserService.rechargeBalanceCallback(out_trade_no, transaction_id);
+            String code = request.getParameter("code");
+            String version = request.getParameter("version");
+            String msg = request.getParameter("msg");
+            String date = request.getParameter("date");
+            String result = request.getParameter("result");
+            String sign = request.getParameter("sign");
+            InterfaceResponse interfaceResponse = new InterfaceResponse();
+            interfaceResponse.setCode(code);
+            interfaceResponse.setVersion(version);
+            interfaceResponse.setMsg(msg);
+            interfaceResponse.setDate(date);
+            interfaceResponse.setResult(result);
+            interfaceResponse.setSign(sign);
+            // 验签
+            boolean verify = RSASignature.validate(interfaceResponse.content(), interfaceResponse.getSign());
+            if (verify) {//验签成功业务处理逻辑
+                JSONObject jsonObject = JSON.parseObject(result);
+                String merOrderId = jsonObject.getString("merOrderId");
+                String orderId = jsonObject.getString("parameter1");
+                appUserService.rechargeBalanceCallback(orderId, merOrderId);
+                response.setStatus(200);
                 PrintWriter out = response.getWriter();
-                out.print(result);
+                out.print("OK");
                 out.flush();
                 out.close();
+            } else {//验签失败业务处理逻辑
+                System.err.println("支付回调验签失败");
             }
+
+//            Map<String, String> map = payMoneyUtil.weixinpayCallback(request);
+//            if(null != map){
+//                String out_trade_no = map.get("out_trade_no");
+//                String transaction_id = map.get("transaction_id");
+//                String result = map.get("result");
+//                String orderId = out_trade_no.substring(17);
+//                appUserService.rechargeBalanceCallback(out_trade_no, transaction_id);
+//                PrintWriter out = response.getWriter();
+//                out.print(result);
+//                out.flush();
+//                out.close();
+//            }
         }catch (Exception e){
             e.printStackTrace();
         }
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/OrderController.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/OrderController.java
index 53d9271..5b37b5e 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/OrderController.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/api/OrderController.java
@@ -1,13 +1,20 @@
 package com.supersavedriving.user.modular.api;
 
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
 import com.supersavedriving.user.core.common.annotion.ServiceLog;
 import com.supersavedriving.user.core.util.ToolUtil;
 import com.supersavedriving.user.modular.system.model.AppUser;
+import com.supersavedriving.user.modular.system.model.Driver;
 import com.supersavedriving.user.modular.system.model.Order;
-import com.supersavedriving.user.modular.system.service.IAppUserService;
-import com.supersavedriving.user.modular.system.service.IBillService;
-import com.supersavedriving.user.modular.system.service.IOrderService;
+import com.supersavedriving.user.modular.system.model.Revenue;
+import com.supersavedriving.user.modular.system.service.*;
+import com.supersavedriving.user.modular.system.util.MallBook.model.InterfaceResponse;
+import com.supersavedriving.user.modular.system.util.MallBook.model.Receive;
+import com.supersavedriving.user.modular.system.util.MallBook.model.ReceiveUser;
+import com.supersavedriving.user.modular.system.util.MallBook.util.RSASignature;
+import com.supersavedriving.user.modular.system.util.MallBook.util.TrhRequest;
 import com.supersavedriving.user.modular.system.util.PayMoneyUtil;
 import com.supersavedriving.user.modular.system.util.ResultUtil;
 import com.supersavedriving.user.modular.system.warpper.*;
@@ -23,9 +30,7 @@
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import java.io.PrintWriter;
-import java.util.Arrays;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
@@ -48,6 +53,12 @@
 
     @Autowired
     private IBillService billService;
+
+    @Autowired
+    private IRevenueService revenueService;
+
+    @Autowired
+    private IDriverService driverService;
 
 
 
@@ -345,19 +356,124 @@
     @PostMapping("/base/order/orderPayCallback")
     public void orderPayCallback(HttpServletRequest request, HttpServletResponse response){
         try {
-            Map<String, String> map = payMoneyUtil.weixinpayCallback(request);
-            if(null != map){
-                String out_trade_no = map.get("out_trade_no");
-                String transaction_id = map.get("transaction_id");
-                String result = map.get("result");
-                String orderId = out_trade_no.substring(17);
-                ResultUtil resultUtil = orderService.orderPayCallback(orderId, transaction_id);
+            String code = request.getParameter("code");
+            String version = request.getParameter("version");
+            String msg = request.getParameter("msg");
+            String date = request.getParameter("date");
+            String result = request.getParameter("result");
+            String sign = request.getParameter("sign");
+            InterfaceResponse interfaceResponse = new InterfaceResponse();
+            interfaceResponse.setCode(code);
+            interfaceResponse.setVersion(version);
+            interfaceResponse.setMsg(msg);
+            interfaceResponse.setDate(date);
+            interfaceResponse.setResult(result);
+            interfaceResponse.setSign(sign);
+            // 验签
+            boolean verify = RSASignature.validate(interfaceResponse.content(), interfaceResponse.getSign());
+            if (verify) {//验签成功业务处理逻辑
+                JSONObject jsonObject = JSON.parseObject(result);
+                String merOrderId = jsonObject.getString("merOrderId");
+                String orderId = jsonObject.getString("parameter1");
+                ResultUtil resultUtil = orderService.orderPayCallback(orderId, merOrderId);
                 if(resultUtil.getCode() == 10000){
+                    response.setStatus(200);
                     PrintWriter out = response.getWriter();
-                    out.print(result);
+                    out.print("OK");
                     out.flush();
                     out.close();
                 }
+            } else {//验签失败业务处理逻辑
+                System.err.println("支付回调验签失败");
+            }
+
+
+//            Map<String, String> map = payMoneyUtil.weixinpayCallback(request);
+//            if(null != map){
+//                String out_trade_no = map.get("out_trade_no");
+//                String transaction_id = map.get("transaction_id");
+//                String result = map.get("result");
+//                String orderId = out_trade_no.substring(17);
+//                ResultUtil resultUtil = orderService.orderPayCallback(orderId, transaction_id);
+//                if(resultUtil.getCode() == 10000){
+//                    PrintWriter out = response.getWriter();
+//                    out.print(result);
+//                    out.flush();
+//                    out.close();
+//                }
+//            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+
+    /**
+     * 异步分账回调
+     */
+    @ResponseBody
+    @PostMapping("/base/order/ledgerCallback")
+    public void ledgerCallback(HttpServletRequest request, HttpServletResponse response){
+        try{
+            String code = request.getParameter("code");
+            String version = request.getParameter("version");
+            String msg = request.getParameter("msg");
+            String date = request.getParameter("date");
+            String result = request.getParameter("result");
+            String sign = request.getParameter("sign");
+            InterfaceResponse interfaceResponse = new InterfaceResponse();
+            interfaceResponse.setCode(code);
+            interfaceResponse.setVersion(version);
+            interfaceResponse.setMsg(msg);
+            interfaceResponse.setDate(date);
+            interfaceResponse.setResult(result);
+            interfaceResponse.setSign(sign);
+            // 验签
+            boolean verify = RSASignature.validate(interfaceResponse.content(), interfaceResponse.getSign());
+            if (verify) {//验签成功业务处理逻辑
+                JSONObject jsonObject = JSON.parseObject(result);
+                String merOrderId = jsonObject.getString("merOrderId");
+                String orderId = jsonObject.getString("parameter1");
+                //确认收货
+                new Timer().schedule(new TimerTask() {
+                    @Override
+                    public void run() {
+                        Order order = orderService.selectById(orderId);
+                        List<Revenue> revenues = revenueService.selectList(new EntityWrapper<Revenue>().eq("userType", 2).eq("orderId", order.getId()));
+                        Receive receive = new Receive();//确认收货
+                        receive.setOriginalMerOrderId(merOrderId);
+                        receive.setRcvAmount(String.valueOf(order.getPayMoney() * 100));
+                        List<ReceiveUser> splitList = new ArrayList<>();
+                        for (Revenue revenue : revenues) {
+                            Driver driver = driverService.selectById(revenue.getUserId());
+                            ReceiveUser receiveUser = new ReceiveUser();
+                            receiveUser.setSplitUserId(driver.getMerchantNumber());
+                            receiveUser.setRcvSplitAmount(revenue.getAmount().toString());
+                            splitList.add(receiveUser);
+                        }
+                        receive.setSplitList(splitList);
+                        TrhRequest<Receive> request1 = new TrhRequest();
+                        InterfaceResponse execute = request1.execute(receive, Receive.SERVICE_CODE);
+                        if(!"0000".equals(execute.getResult())){
+                            System.err.println("确认收货" + execute.getMsg());
+                        }
+                        JSONObject jsonObject = JSON.parseObject(execute.getResult());
+                        String status = jsonObject.getString("status");
+                        if("2".equals(status)){
+                            System.err.println("确认收货失败");
+                        }
+                        if("0".equals(status)){
+                            System.err.println("确认收货处理中");
+                        }
+                    }
+                }, 30000);
+                response.setStatus(200);
+                PrintWriter out = response.getWriter();
+                out.print("OK");
+                out.flush();
+                out.close();
+            } else {//验签失败业务处理逻辑
+                System.err.println("支付回调验签失败");
             }
         }catch (Exception e){
             e.printStackTrace();
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/AgentMapper.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/AgentMapper.java
new file mode 100644
index 0000000..bc8c2a6
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/AgentMapper.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.dao;
+
+import com.baomidou.mybatisplus.mapper.BaseMapper;
+import com.supersavedriving.user.modular.system.model.Agent;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 11:52
+ */
+public interface AgentMapper extends BaseMapper<Agent> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/DivisionRecordMapper.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/DivisionRecordMapper.java
new file mode 100644
index 0000000..088bb93
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/DivisionRecordMapper.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.dao;
+
+import com.baomidou.mybatisplus.mapper.BaseMapper;
+import com.supersavedriving.user.modular.system.model.DivisionRecord;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 16:41
+ */
+public interface DivisionRecordMapper extends BaseMapper<DivisionRecord> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/PlatformRechargeRecordMapper.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/PlatformRechargeRecordMapper.java
new file mode 100644
index 0000000..f8589f0
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/PlatformRechargeRecordMapper.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.dao;
+
+import com.baomidou.mybatisplus.mapper.BaseMapper;
+import com.supersavedriving.user.modular.system.model.PlatformRechargeRecord;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 14:09
+ */
+public interface PlatformRechargeRecordMapper extends BaseMapper<PlatformRechargeRecord> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/AgentMapper.xml b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/AgentMapper.xml
new file mode 100644
index 0000000..1496d17
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/AgentMapper.xml
@@ -0,0 +1,21 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.supersavedriving.user.modular.system.dao.AgentMapper">
+
+    <!-- 通用查询映射结果 -->
+    <resultMap id="BaseResultMap" type="com.supersavedriving.user.modular.system.model.Agent">
+        <id column="id" property="id"/>
+        <result column="principal" property="principal"/>
+        <result column="principalPhone" property="principalPhone"/>
+        <result column="email" property="email"/>
+        <result column="provinceName" property="provinceName"/>
+        <result column="provinceCode" property="provinceCode"/>
+        <result column="cityCode" property="cityCode"/>
+        <result column="cityName" property="cityName"/>
+        <result column="status" property="status"/>
+        <result column="createTime" property="createTime"/>
+        <result column="bankDeposit" property="bankDeposit"/>
+        <result column="bankAccount" property="bankAccount"/>
+        <result column="serviceCalls" property="serviceCalls"/>
+    </resultMap>
+</mapper>
\ No newline at end of file
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DivisionRecordMapper.xml b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DivisionRecordMapper.xml
new file mode 100644
index 0000000..ba57e81
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DivisionRecordMapper.xml
@@ -0,0 +1,19 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.supersavedriving.user.modular.system.dao.DivisionRecordMapper">
+
+    <!-- 通用查询映射结果 -->
+    <resultMap id="BaseResultMap" type="com.supersavedriving.user.modular.system.model.DivisionRecord">
+        <id column="id" property="id"/>
+        <result column="userType" property="userType"/>
+        <result column="userId" property="userId"/>
+        <result column="orderId" property="orderId"/>
+        <result column="merOrderId" property="merOrderId"/>
+        <result column="sourceType" property="sourceType"/>
+        <result column="amount" property="amount"/>
+        <result column="merchantNumber" property="merchantNumber"/>
+        <result column="state" property="state"/>
+        <result column="payTime" property="payTime"/>
+        <result column="createTime" property="createTime"/>
+    </resultMap>
+</mapper>
\ No newline at end of file
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DriverMapper.xml b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DriverMapper.xml
index 3d62685..47880ea 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DriverMapper.xml
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/DriverMapper.xml
@@ -47,5 +47,9 @@
         <result column="commission" property="commission"/>
         <result column="wxCollectionCode" property="wxCollectionCode"/>
         <result column="zfbCollectionCode" property="zfbCollectionCode"/>
+        <result column="merchantNumber" property="merchantNumber"/>
+        <result column="merchantName" property="merchantName"/>
+        <result column="merchantPhone" property="merchantPhone"/>
+        <result column="merchantIDCode" property="merchantIDCode"/>
     </resultMap>
 </mapper>
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/OrderMapper.xml b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/OrderMapper.xml
index d55f4d2..5885545 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/OrderMapper.xml
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/OrderMapper.xml
@@ -97,7 +97,7 @@
     <select id="queryMyOrder" resultType="com.supersavedriving.user.modular.system.warpper.OrderListWarpper">
         select
         id,
-        '超省新代驾' as title,
+        '超省新代驾订单' as title,
         startAddress,
         endAddress,
         state,
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/PlatformRechargeRecordMapper.xml b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/PlatformRechargeRecordMapper.xml
new file mode 100644
index 0000000..5336a6a
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/dao/mapping/PlatformRechargeRecordMapper.xml
@@ -0,0 +1,16 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.supersavedriving.user.modular.system.dao.PlatformRechargeRecordMapper">
+
+    <!-- 通用查询映射结果 -->
+    <resultMap id="BaseResultMap" type="com.supersavedriving.user.modular.system.model.PlatformRechargeRecord">
+        <id column="id" property="id"/>
+        <result column="orderId" property="orderId"/>
+        <result column="price" property="price"/>
+        <result column="orderNumber" property="orderNumber"/>
+        <result column="balance" property="balance"/>
+        <result column="state" property="state"/>
+        <result column="payTime" property="payTime"/>
+        <result column="createTime" property="createTime"/>
+    </resultMap>
+</mapper>
\ No newline at end of file
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Agent.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Agent.java
new file mode 100644
index 0000000..5c54a54
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Agent.java
@@ -0,0 +1,105 @@
+package com.supersavedriving.user.modular.system.model;
+
+import com.baomidou.mybatisplus.annotations.TableField;
+import com.baomidou.mybatisplus.annotations.TableId;
+import com.baomidou.mybatisplus.annotations.TableName;
+import com.baomidou.mybatisplus.enums.IdType;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * 代理商
+ * @author zhibing.pu
+ * @date 2023/3/22 22:29
+ */
+@Data
+@TableName("t_agent")
+public class Agent {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    @TableField("id")
+    private Integer id;
+    /**
+     * 负责人姓名
+     */
+    @TableField("principal")
+    private String principal;
+    /**
+     * 负责人电话
+     */
+    @TableField("principalPhone")
+    private String principalPhone;
+    /**
+     * 邮箱
+     */
+    @TableField("email")
+    private String email;
+    /**
+     * 代理区域省名称
+     */
+    @TableField("provinceName")
+    private String provinceName;
+    /**
+     * 代理区域省编号
+     */
+    @TableField("provinceCode")
+    private String provinceCode;
+    /**
+     * 代理区域市编号
+     */
+    @TableField("cityCode")
+    private String cityCode;
+    /**
+     * 代理区域市名称
+     */
+    @TableField("cityName")
+    private String cityName;
+    /**
+     * 状态(1=正常,2=冻结,3=删除)
+     */
+    @TableField("status")
+    private Integer status;
+    /**
+     * 添加时间
+     */
+    @TableField("createTime")
+    private Date createTime;
+    /**
+     * 开户银行
+     */
+    @TableField("bankDeposit")
+    private String bankDeposit;
+    /**
+     * 银行账号
+     */
+    @TableField("bankAccount")
+    private String bankAccount;
+    /**
+     * 客服电话
+     */
+    @TableField("serviceCalls")
+    private String serviceCalls;
+    /**
+     * 商户号
+     */
+    @TableField("merchantNumber")
+    private String merchantNumber;
+    /**
+     * 商户姓名
+     */
+    @TableField("merchantName")
+    private String merchantName;
+    /**
+     * 商户电话
+     */
+    @TableField("merchantPhone")
+    private String merchantPhone;
+    /**
+     * 商户身份证号码
+     */
+    @TableField("merchantIDCode")
+    private String merchantIDCode;
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/DivisionRecord.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/DivisionRecord.java
new file mode 100644
index 0000000..bac85da
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/DivisionRecord.java
@@ -0,0 +1,73 @@
+package com.supersavedriving.user.modular.system.model;
+
+import com.baomidou.mybatisplus.annotations.TableField;
+import com.baomidou.mybatisplus.annotations.TableId;
+import com.baomidou.mybatisplus.annotations.TableName;
+import com.baomidou.mybatisplus.enums.IdType;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 15:54
+ */
+@Data
+@TableName("t_division_record")
+public class DivisionRecord {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+    /**
+     * 用户类型(1=司机,2=代理商,3=平台)
+     */
+    @TableField("userType")
+    private Integer userType;
+    /**
+     * 用户id
+     */
+    @TableField("userId")
+    private Integer userId;
+    /**
+     * 分账业务订单id
+     */
+    @TableField("orderId")
+    private Long orderId;
+    /**
+     * 第三方分账业务订单id
+     */
+    @TableField("merOrderId")
+    private String merOrderId;
+    /**
+     * 业务来源(1=订单业务,2=平台充值)
+     */
+    @TableField("sourceType")
+    private Integer sourceType;
+    /**
+     * 分账金额
+     */
+    @TableField("amount")
+    private Double amount;
+    /**
+     * 收款商户号
+     */
+    @TableField("merchantNumber")
+    private String merchantNumber;
+    /**
+     * 分账状态(1=分账中,2=分账成功)
+     */
+    @TableField("state")
+    private Integer state;
+    /**
+     * 分账时间
+     */
+    @TableField("payTime")
+    private Date payTime;
+    /**
+     * 添加时间
+     */
+    @TableField("createTime")
+    private Date createTime;
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Driver.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Driver.java
index f80a33a..54ea90c 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Driver.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Driver.java
@@ -227,4 +227,24 @@
      */
     @TableField("zfbCollectionCode")
     private String zfbCollectionCode;
+    /**
+     * 商户号
+     */
+    @TableField("merchantNumber")
+    private String merchantNumber;
+    /**
+     * 商户姓名
+     */
+    @TableField("merchantName")
+    private String merchantName;
+    /**
+     * 商户电话
+     */
+    @TableField("merchantPhone")
+    private String merchantPhone;
+    /**
+     * 商户身份证号码
+     */
+    @TableField("merchantIDCode")
+    private String merchantIDCode;
 }
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Order.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Order.java
index 0294c69..4aa6a66 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Order.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/Order.java
@@ -218,6 +218,11 @@
     @TableField("estimatedMileage")
     private Double estimatedMileage;
     /**
+     * 预估时间
+     */
+    @TableField("estimatedTime")
+    private Integer estimatedTime;
+    /**
      * 订单金额
      */
     @TableField("orderMoney")
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/PlatformRechargeRecord.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/PlatformRechargeRecord.java
new file mode 100644
index 0000000..f1ea486
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/PlatformRechargeRecord.java
@@ -0,0 +1,58 @@
+package com.supersavedriving.user.modular.system.model;
+
+import com.baomidou.mybatisplus.annotations.TableField;
+import com.baomidou.mybatisplus.annotations.TableId;
+import com.baomidou.mybatisplus.annotations.TableName;
+import com.baomidou.mybatisplus.enums.IdType;
+import lombok.Data;
+
+import java.util.Date;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 14:05
+ */
+@Data
+@TableName("t_platform_recharge_record")
+public class PlatformRechargeRecord {
+    /**
+     * 主键
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+    /**
+     * 订单号
+     */
+    @TableField("orderId")
+    private String orderId;
+    /**
+     * 充值金额
+     */
+    @TableField("price")
+    private Double price;
+    /**
+     * 第三方支付流水号
+     */
+    @TableField("orderNumber")
+    private String orderNumber;
+    /**
+     * 余额
+     */
+    @TableField("balance")
+    private Double balance;
+    /**
+     * 支付状态(1=待支付,2=已支付,3=已取消)
+     */
+    @TableField("state")
+    private Integer state;
+    /**
+     * 支付时间
+     */
+    @TableField("payTime")
+    private Date payTime;
+    /**
+     * 添加时间
+     */
+    @TableField("createTime")
+    private Date createTime;
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/RechargeRecord.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/RechargeRecord.java
index 740115b..5be8070 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/RechargeRecord.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/RechargeRecord.java
@@ -42,6 +42,11 @@
     @TableField("amount")
     private Double amount;
     /**
+     * 未分配金额
+     */
+    @TableField("unallocatedAmount")
+    private Double unallocatedAmount;
+    /**
      * 支付方式(1=微信,2=系统充值)
      */
     @TableField("payType")
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/YouTuiDriver.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/YouTuiDriver.java
index 914bf3d..6d0b610 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/YouTuiDriver.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/model/YouTuiDriver.java
@@ -51,7 +51,7 @@
      * 优推结束时间
      */
     @TableField("endTime")
-    private Integer endTime;
+    private Date endTime;
     /**
      * 状态(1=未使用,2=使用中,3=已结束)
      */
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IAgentService.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IAgentService.java
new file mode 100644
index 0000000..226b9a5
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IAgentService.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.service;
+
+import com.baomidou.mybatisplus.service.IService;
+import com.supersavedriving.user.modular.system.model.Agent;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 11:53
+ */
+public interface IAgentService extends IService<Agent> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IDivisionRecordService.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IDivisionRecordService.java
new file mode 100644
index 0000000..64381d9
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IDivisionRecordService.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.service;
+
+import com.baomidou.mybatisplus.service.IService;
+import com.supersavedriving.user.modular.system.model.DivisionRecord;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 16:42
+ */
+public interface IDivisionRecordService extends IService<DivisionRecord> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IPlatformRechargeRecordService.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IPlatformRechargeRecordService.java
new file mode 100644
index 0000000..faf5eff
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/IPlatformRechargeRecordService.java
@@ -0,0 +1,11 @@
+package com.supersavedriving.user.modular.system.service;
+
+import com.baomidou.mybatisplus.service.IService;
+import com.supersavedriving.user.modular.system.model.PlatformRechargeRecord;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 14:10
+ */
+public interface IPlatformRechargeRecordService extends IService<PlatformRechargeRecord> {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AgentServiceImpl.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AgentServiceImpl.java
new file mode 100644
index 0000000..b551b06
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AgentServiceImpl.java
@@ -0,0 +1,15 @@
+package com.supersavedriving.user.modular.system.service.impl;
+
+import com.baomidou.mybatisplus.service.impl.ServiceImpl;
+import com.supersavedriving.user.modular.system.dao.AgentMapper;
+import com.supersavedriving.user.modular.system.model.Agent;
+import com.supersavedriving.user.modular.system.service.IAgentService;
+import org.springframework.stereotype.Service;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 11:53
+ */
+@Service
+public class AgentServiceImpl extends ServiceImpl<AgentMapper, Agent> implements IAgentService {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AppUserServiceImpl.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AppUserServiceImpl.java
index 02bbbe2..7264bc4 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AppUserServiceImpl.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/AppUserServiceImpl.java
@@ -13,6 +13,10 @@
 import com.supersavedriving.user.modular.system.dao.AppUserMapper;
 import com.supersavedriving.user.modular.system.model.*;
 import com.supersavedriving.user.modular.system.service.*;
+import com.supersavedriving.user.modular.system.util.MallBook.model.InterfaceResponse;
+import com.supersavedriving.user.modular.system.util.MallBook.model.PaymentOrder;
+import com.supersavedriving.user.modular.system.util.MallBook.model.PaymentOrderGood;
+import com.supersavedriving.user.modular.system.util.MallBook.util.TrhRequest;
 import com.supersavedriving.user.modular.system.util.PayMoneyUtil;
 import com.supersavedriving.user.modular.system.util.RedisUtil;
 import com.supersavedriving.user.modular.system.util.ResultUtil;
@@ -27,11 +31,13 @@
 import org.apache.shiro.crypto.hash.Md5Hash;
 import org.apache.shiro.util.ByteSource;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 import org.springframework.web.context.request.RequestContextHolder;
 import org.springframework.web.context.request.ServletRequestAttributes;
 
 import javax.servlet.http.HttpServletRequest;
+import java.net.InetAddress;
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
 import java.util.Date;
@@ -66,6 +72,12 @@
 
     @Autowired
     private IAccountChangeDetailService accountChangeDetailService;
+
+    @Value("${callbackPath}")
+    private String callbackPath;//支付回调网关地址
+
+    @Value("${wx.appletsAppid}")
+    private String appletsAppid;
 
 
 
@@ -156,6 +168,7 @@
         if(null == appUser){
             appUser = new AppUser();
             appUser.setNickname("亲爱的用户");
+            appUser.setAvatar("https://csxdj.obs.cn-south-1.myhuaweicloud.com:443/66cc269703a84e4da87fb21e2c21ab1f.png");
             appUser.setPhone(purePhoneNumber);
             appUser.setOpenid(openid);
             appUser.setUnionid(code2Session.getUnionid());
@@ -301,8 +314,43 @@
         rechargeRecord.setPayStatus(1);
         rechargeRecord.setPayType(1);
         rechargeRecordService.insert(rechargeRecord);
-        ResultUtil weixinpay = payMoneyUtil.weixinpay("余额充值", "", out_trade_no, amount.toString(), "/base/appUser/rechargeBalanceCallback", "JSAPI", appUser.getOpenid());
-        return weixinpay;
+//        ResultUtil weixinpay = payMoneyUtil.weixinpay("余额充值", "", out_trade_no, amount.toString(), "/base/appUser/rechargeBalanceCallback", "JSAPI", appUser.getOpenid());
+//        return weixinpay;
+
+        PaymentOrder paymentOrder = new PaymentOrder();
+        paymentOrder.setBizOrderId(out_trade_no);
+        paymentOrder.setAmount(String.valueOf(amount * 100));
+        paymentOrder.setOrderName("余额充值");
+        paymentOrder.setPayType("WX_MINI");
+        paymentOrder.setTransferType("0");
+        paymentOrder.setAsynSplitFlag("1");
+        paymentOrder.setAppid(appletsAppid);
+        paymentOrder.setOpenid(appUser.getOpenid());
+        paymentOrder.setTerminalIp(InetAddress.getLocalHost().getHostAddress());
+        List<PaymentOrderGood> goodsDetail = new ArrayList<>();
+        PaymentOrderGood paymentOrderGood = new PaymentOrderGood();
+        paymentOrderGood.setGoodsName("余额充值");
+        goodsDetail.add(paymentOrderGood);
+        paymentOrder.setGoodsDetail(goodsDetail);
+        paymentOrder.setFrontUrl("");
+        paymentOrder.setNotifyUrl(callbackPath + "/base/appUser/rechargeBalanceCallback");
+        paymentOrder.setParameter1(out_trade_no);
+
+        TrhRequest<PaymentOrder> request = new TrhRequest();
+        InterfaceResponse execute = request.execute(paymentOrder, PaymentOrder.SERVICE_CODE);
+        if(!"0000".equals(execute.getResult())){
+            return ResultUtil.error(execute.getMsg());
+        }
+        JSONObject jsonObject = JSON.parseObject(execute.getResult());
+        String status = jsonObject.getString("status");
+        if("2".equals(status)){
+            return ResultUtil.error("失败");
+        }
+        if("0".equals(status)){
+            return ResultUtil.error("处理中");
+        }
+        String payCode = jsonObject.getString("payCode");
+        return ResultUtil.success(payCode);
     }
 
 
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/DivisionRecordServiceImpl.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/DivisionRecordServiceImpl.java
new file mode 100644
index 0000000..fd96cff
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/DivisionRecordServiceImpl.java
@@ -0,0 +1,15 @@
+package com.supersavedriving.user.modular.system.service.impl;
+
+import com.baomidou.mybatisplus.service.impl.ServiceImpl;
+import com.supersavedriving.user.modular.system.dao.DivisionRecordMapper;
+import com.supersavedriving.user.modular.system.model.DivisionRecord;
+import com.supersavedriving.user.modular.system.service.IDivisionRecordService;
+import org.springframework.stereotype.Service;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 16:42
+ */
+@Service
+public class DivisionRecordServiceImpl extends ServiceImpl<DivisionRecordMapper, DivisionRecord> implements IDivisionRecordService {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/OrderServiceImpl.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/OrderServiceImpl.java
index 49c1200..fd6c398 100644
--- a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/OrderServiceImpl.java
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/OrderServiceImpl.java
@@ -12,11 +12,15 @@
 import com.supersavedriving.user.modular.system.util.*;
 import com.supersavedriving.user.modular.system.util.GaoDe.MapUtil;
 import com.supersavedriving.user.modular.system.util.GaoDe.model.District;
+import com.supersavedriving.user.modular.system.util.MallBook.model.*;
+import com.supersavedriving.user.modular.system.util.MallBook.util.Transfer;
+import com.supersavedriving.user.modular.system.util.MallBook.util.TrhRequest;
 import com.supersavedriving.user.modular.system.util.juhe.WeatherUtil;
 import com.supersavedriving.user.modular.system.util.mongodb.model.Location;
 import com.supersavedriving.user.modular.system.warpper.*;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.data.geo.Circle;
 import org.springframework.data.geo.Distance;
 import org.springframework.data.geo.Metrics;
@@ -29,6 +33,7 @@
 import java.math.BigDecimal;
 import java.math.MathContext;
 import java.math.RoundingMode;
+import java.net.InetAddress;
 import java.text.SimpleDateFormat;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -89,6 +94,18 @@
 
     @Autowired
     private IRevenueService revenueService;
+
+    @Autowired
+    private IAgentService agentService;
+
+    @Autowired
+    private IPlatformRechargeRecordService platformRechargeRecordService;
+
+    @Autowired
+    private IDivisionRecordService divisionRecordService;
+
+    @Value("${callbackPath}")
+    private String callbackPath;//支付回调网关地址
 
 
 
@@ -370,11 +387,13 @@
         String startAddress = travelOrder.getStartAddress();
         startAddress = startAddress.replaceAll("& #40;", "(");
         startAddress = startAddress.replaceAll("& #41;", ")");
-        travelOrder.setStartAddress(startAddress);;
-        String endAddress = travelOrder.getEndAddress();
-        endAddress = endAddress.replaceAll("& #40;", "(");
-        endAddress = endAddress.replaceAll("& #41;", ")");
-        travelOrder.setEndAddress(endAddress);
+        travelOrder.setStartAddress(startAddress);
+        if(ToolUtil.isNotEmpty(travelOrder.getEndAddress())){
+            String endAddress = travelOrder.getEndAddress();
+            endAddress = endAddress.replaceAll("& #40;", "(");
+            endAddress = endAddress.replaceAll("& #41;", ")");
+            travelOrder.setEndAddress(endAddress);
+        }
 
         order = new Order();
         BeanUtils.copyProperties(travelOrder, order);
@@ -383,7 +402,6 @@
             order.setUserName(appUser.getNickname());
         }
         order.setUserId(uid);
-        order.setCode(UUIDUtil.getTimeStr() + UUIDUtil.getNumberRandom(3));
         order.setSource(1);
         order.setHallOrder(0);
         order.setStatus(1);
@@ -397,6 +415,7 @@
             }
             d = Double.valueOf(distance.get("distance")) / 1000;
             order.setEstimatedMileage(d);
+            order.setEstimatedTime(Integer.valueOf(distance.get("duration")) / 60);
         }
         String city = "";
         District geocode = MapUtil.geocode(order.getStartLng(), order.getStartLat());
@@ -425,6 +444,7 @@
 
         for (Integer i = 0; i < travelOrder.getDriverNum(); i++) {
             order.setId(null);
+            order.setCode(UUIDUtil.getTimeStr() + UUIDUtil.getNumberRandom(3));
             this.insert(order);
 
             //推送状态
@@ -676,6 +696,7 @@
             }
             d = Double.valueOf(distance.get("distance")) / 1000;
             order.setEstimatedMileage(d);
+            order.setEstimatedTime(Integer.valueOf(distance.get("duration")) / 60);
         }
         String city = "";
         District geocode = MapUtil.geocode(order.getStartLng().toString(), order.getStartLat().toString());
@@ -848,9 +869,46 @@
         order.setPayMoney(payMoney);
         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
         String out_trade_no = sdf.format(new Date()) + order.getId();
-        ResultUtil weixinpay = payMoneyUtil.weixinpay("代驾服务费", "", out_trade_no, payMoney.toString(), "/base/order/orderPayCallback", "JSAPI", appUser.getOpenid());
+//        ResultUtil weixinpay = payMoneyUtil.weixinpay("代驾服务费", "", out_trade_no, payMoney.toString(), "/base/order/orderPayCallback", "JSAPI", appUser.getOpenid());
+//        this.updateById(order);
+
+
+
+        PaymentOrder paymentOrder = new PaymentOrder();
+        paymentOrder.setBizOrderId(out_trade_no);
+        paymentOrder.setAmount(String.valueOf(payMoney * 100));
+        paymentOrder.setOrderName("代驾服务费");
+        paymentOrder.setPayType("WX_MINI");
+        paymentOrder.setTransferType("0");
+        paymentOrder.setAsynSplitFlag("1");
+        paymentOrder.setAppid("");
+        paymentOrder.setOpenid(appUser.getOpenid());
+        paymentOrder.setTerminalIp(InetAddress.getLocalHost().getHostAddress());
+        List<PaymentOrderGood> goodsDetail = new ArrayList<>();
+        PaymentOrderGood paymentOrderGood = new PaymentOrderGood();
+        paymentOrderGood.setGoodsName("服务费");
+        goodsDetail.add(paymentOrderGood);
+        paymentOrder.setGoodsDetail(goodsDetail);
+        paymentOrder.setFrontUrl("");
+        paymentOrder.setNotifyUrl(callbackPath + "/base/order/orderPayCallback");
+        paymentOrder.setParameter1(order.getId().toString());
+
+        TrhRequest<PaymentOrder> request = new TrhRequest();
+        InterfaceResponse execute = request.execute(paymentOrder, PaymentOrder.SERVICE_CODE);
+        if(!"0000".equals(execute.getResult())){
+            return ResultUtil.error(execute.getMsg());
+        }
+        JSONObject jsonObject = JSON.parseObject(execute.getResult());
+        String status = jsonObject.getString("status");
+        if("2".equals(status)){
+            return ResultUtil.error("失败");
+        }
+        if("0".equals(status)){
+            return ResultUtil.error("处理中");
+        }
+        String payCode = jsonObject.getString("payCode");
         this.updateById(order);
-        return weixinpay;
+        return ResultUtil.success(payCode);
     }
 
 
@@ -895,6 +953,7 @@
 
 
         AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+        accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
         accountChangeDetail.setUserType(1);
         accountChangeDetail.setUserId(appUser.getId());
         accountChangeDetail.setCreateTime(new Date());
@@ -940,6 +999,7 @@
         payMoney = payMoney > appUser.getAccountBalance() ? payMoney - appUser.getAccountBalance() : 0D;
 
         AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+        accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
         accountChangeDetail.setUserType(1);
         accountChangeDetail.setUserId(appUser.getId());
         accountChangeDetail.setCreateTime(new Date());
@@ -956,88 +1016,127 @@
         if(0 < payMoney){//还需要调起微信支付
             SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
             String out_trade_no = sdf.format(new Date()) + order.getId();
-            ResultUtil weixinpay = payMoneyUtil.weixinpay("代驾服务费", "", out_trade_no, payMoney.toString(), "/base/order/orderPayCallback", "JSAPI", appUser.getOpenid());
+//            ResultUtil weixinpay = payMoneyUtil.weixinpay("代驾服务费", "", out_trade_no, payMoney.toString(), "/base/order/orderPayCallback", "JSAPI", appUser.getOpenid());
 
-            new Thread(new Runnable() {
-                @Override
-                public void run() {
-                    try {
-                        int num = 1;
-                        int wait = 0;
-                        while (num <= 10){
-                            int min = 5000;
-                            wait += (min * num);
-                            Order order1 = OrderServiceImpl.this.selectById(order.getId());
-                            if(order1.getState() != 107){
-                                return;
-                            }
+            PaymentOrder paymentOrder = new PaymentOrder();
+            paymentOrder.setBizOrderId(out_trade_no);
+            paymentOrder.setAmount(String.valueOf(payMoney * 100));
+            paymentOrder.setOrderName("代驾服务费");
+            paymentOrder.setPayType("WX_MINI");
+            paymentOrder.setTransferType("0");
+            paymentOrder.setAsynSplitFlag("1");
+            paymentOrder.setAppid("");
+            paymentOrder.setOpenid(appUser.getOpenid());
+            paymentOrder.setTerminalIp(InetAddress.getLocalHost().getHostAddress());
+            List<PaymentOrderGood> goodsDetail = new ArrayList<>();
+            PaymentOrderGood paymentOrderGood = new PaymentOrderGood();
+            paymentOrderGood.setGoodsName("服务费");
+            goodsDetail.add(paymentOrderGood);
+            paymentOrder.setGoodsDetail(goodsDetail);
+            paymentOrder.setFrontUrl("");
+            paymentOrder.setNotifyUrl(callbackPath + "/base/order/orderPayCallback");
+            paymentOrder.setParameter1(order.getId().toString());
 
-                            /**
-                             * SUCCESS--支付成功
-                             * REFUND--转入退款
-                             * NOTPAY--未支付
-                             * CLOSED--已关闭
-                             * REVOKED--已撤销(刷卡支付)
-                             * USERPAYING--用户支付中
-                             * PAYERROR--支付失败(其他原因,如银行返回失败)
-                             * ACCEPT--已接收,等待扣款
-                             */
-                            ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(out_trade_no, "");
-                            if(resultUtil.getCode() == 200){
-                                Map<String, String> map = resultUtil.getData();
-                                String trade_type = map.get("trade_type");
-                                String trade_state = map.get("trade_state");
-                                String transaction_id = map.get("transaction_id");
-                                if("REFUND".equals(trade_state) || "NOTPAY".equals(trade_state) || "CLOSED".equals(trade_state) || "REVOKED".equals(trade_state) || "PAYERROR".equals(trade_state)){
-                                    AccountChangeDetail accountChangeDetail1 = accountChangeDetailService.selectById(accountChangeDetail.getId());
-                                    AppUser appUser1 = appUserService.selectById(accountChangeDetail1.getUserId());
-                                    Double b = accountChangeDetail1.getOldData() - accountChangeDetail1.getNewData();
-                                    appUser1.setAccountBalance(appUser1.getAccountBalance() + b);
-                                    appUserService.updateById(appUser1);
+            TrhRequest<PaymentOrder> request = new TrhRequest();
+            InterfaceResponse execute = request.execute(paymentOrder, PaymentOrder.SERVICE_CODE);
+            if(!"0000".equals(execute.getResult())){
+                return ResultUtil.error(execute.getMsg());
+            }
+            JSONObject jsonObject = JSON.parseObject(execute.getResult());
+            String status = jsonObject.getString("status");
+            if("2".equals(status)){
+                return ResultUtil.error("失败");
+            }
+            if("0".equals(status)){
+                return ResultUtil.error("处理中");
+            }
+            String payCode = jsonObject.getString("payCode");
+            this.updateById(order);
+            return ResultUtil.success(payCode);
 
-                                    accountChangeDetailService.deleteById(accountChangeDetail.getId());
-                                    return;
-                                }
-                                if("SUCCESS".equals(trade_state)){
-                                    order1.setPayTime(new Date());
-                                    order1.setState(108);
-                                    order1.setOrderNo(transaction_id);
-                                    OrderServiceImpl.this.updateById(order1);
-
-                                    //处理抽成及收入
-                                    saveCommission(order1);
-                                    return;
-                                }
-                                if("USERPAYING".equals(trade_state) || "ACCEPT".equals(trade_state)){
-                                    Thread.sleep(wait);
-                                    num++;
-                                }
-                            }else{
-                                Thread.sleep(wait);
-                                num++;
-                            }
-                            if(10 == num){
-                                AccountChangeDetail accountChangeDetail1 = accountChangeDetailService.selectById(accountChangeDetail.getId());
-                                AppUser appUser1 = appUserService.selectById(accountChangeDetail1.getUserId());
-                                Double b = accountChangeDetail1.getOldData() - accountChangeDetail1.getNewData();
-                                appUser1.setAccountBalance(appUser1.getAccountBalance() + b);
-                                appUserService.updateById(appUser1);
-
-                                accountChangeDetailService.deleteById(accountChangeDetail.getId());
-                            }
-                        }
-                    }catch (Exception e){
-                        e.printStackTrace();
-                    }
-                }
-            }).start();
-            return weixinpay;
+//
+//
+//            new Thread(new Runnable() {
+//                @Override
+//                public void run() {
+//                    try {
+//                        int num = 1;
+//                        int wait = 0;
+//                        while (num <= 10){
+//                            int min = 5000;
+//                            wait += (min * num);
+//                            Order order1 = OrderServiceImpl.this.selectById(order.getId());
+//                            if(order1.getState() != 107){
+//                                return;
+//                            }
+//
+//                            /**
+//                             * SUCCESS--支付成功
+//                             * REFUND--转入退款
+//                             * NOTPAY--未支付
+//                             * CLOSED--已关闭
+//                             * REVOKED--已撤销(刷卡支付)
+//                             * USERPAYING--用户支付中
+//                             * PAYERROR--支付失败(其他原因,如银行返回失败)
+//                             * ACCEPT--已接收,等待扣款
+//                             */
+//                            ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(out_trade_no, "");
+//                            if(resultUtil.getCode() == 200){
+//                                Map<String, String> map = resultUtil.getData();
+//                                String trade_type = map.get("trade_type");
+//                                String trade_state = map.get("trade_state");
+//                                String transaction_id = map.get("transaction_id");
+//                                if("REFUND".equals(trade_state) || "NOTPAY".equals(trade_state) || "CLOSED".equals(trade_state) || "REVOKED".equals(trade_state) || "PAYERROR".equals(trade_state)){
+//                                    AccountChangeDetail accountChangeDetail1 = accountChangeDetailService.selectById(accountChangeDetail.getId());
+//                                    AppUser appUser1 = appUserService.selectById(accountChangeDetail1.getUserId());
+//                                    Double b = accountChangeDetail1.getOldData() - accountChangeDetail1.getNewData();
+//                                    appUser1.setAccountBalance(appUser1.getAccountBalance() + b);
+//                                    appUserService.updateById(appUser1);
+//
+//                                    accountChangeDetailService.deleteById(accountChangeDetail.getId());
+//                                    return;
+//                                }
+//                                if("SUCCESS".equals(trade_state)){
+//                                    order1.setPayTime(new Date());
+//                                    order1.setState(108);
+//                                    order1.setOrderNo(transaction_id);
+//                                    OrderServiceImpl.this.updateById(order1);
+//
+//                                    //处理抽成及收入
+//                                    saveCommission(order1);
+//                                    return;
+//                                }
+//                                if("USERPAYING".equals(trade_state) || "ACCEPT".equals(trade_state)){
+//                                    Thread.sleep(wait);
+//                                    num++;
+//                                }
+//                            }else{
+//                                Thread.sleep(wait);
+//                                num++;
+//                            }
+//                            if(10 == num){
+//                                AccountChangeDetail accountChangeDetail1 = accountChangeDetailService.selectById(accountChangeDetail.getId());
+//                                AppUser appUser1 = appUserService.selectById(accountChangeDetail1.getUserId());
+//                                Double b = accountChangeDetail1.getOldData() - accountChangeDetail1.getNewData();
+//                                appUser1.setAccountBalance(appUser1.getAccountBalance() + b);
+//                                appUserService.updateById(appUser1);
+//
+//                                accountChangeDetailService.deleteById(accountChangeDetail.getId());
+//                            }
+//                        }
+//                    }catch (Exception e){
+//                        e.printStackTrace();
+//                    }
+//                }
+//            }).start();
+//            return weixinpay;
         }
-        order.setPayTime(new Date());
-        this.updateById(order);
+//        order.setPayTime(new Date());
+//        this.updateById(order);
 
 
         return ResultUtil.success();
+
     }
 
     /**
@@ -1066,8 +1165,125 @@
             pushOrderInfoWarpper.setState(order.getState());
             pushUtil.pushOrderInfo(order.getDriverId(), 2, pushOrderInfoWarpper);
         }
+
+        //支付成功---->异步分账----->10s钟后再进行确认收货
+        //确认收货后才能进行提现(结算接口)
+        //异步分账
+        List<Revenue> revenues = revenueService.selectList(new EntityWrapper<Revenue>().eq("orderId", order.getId()));
+        Complete complete = new Complete();
+        complete.setOriginalMerOrderId(transaction_id);
+        complete.setNotifyUrl(callbackPath + "/base/order/ledgerCallback");
+        List<PamentOrderUser> splitList = new ArrayList<>();
+        for (Revenue revenue : revenues) {
+            if(revenue.getUserType() == 2){//司机
+                Driver driver = driverService.selectById(revenue.getUserId());
+                PamentOrderUser pamentOrderUser = new PamentOrderUser();
+                pamentOrderUser.setSplitUserId(driver.getMerchantNumber());
+                pamentOrderUser.setSplitAmount(revenue.getAmount().toString());
+                pamentOrderUser.setSplitType("2");
+                splitList.add(pamentOrderUser);
+
+                DivisionRecord divisionRecord = new DivisionRecord();
+                divisionRecord.setUserType(1);
+                divisionRecord.setUserId(revenue.getUserId());
+                divisionRecord.setOrderId(order.getId());
+                divisionRecord.setMerOrderId(transaction_id);
+                divisionRecord.setSourceType(1);
+                divisionRecord.setAmount(revenue.getAmount());
+                divisionRecord.setMerchantNumber(driver.getMerchantNumber());
+                divisionRecord.setState(1);
+                divisionRecord.setCreateTime(new Date());
+                divisionRecordService.insert(divisionRecord);
+            }
+            if(revenue.getUserType() == 3){//代理商
+                Agent agent = agentService.selectById(revenue.getUserId());
+                PamentOrderUser pamentOrderUser = new PamentOrderUser();
+                pamentOrderUser.setSplitUserId(agent.getMerchantNumber());
+                pamentOrderUser.setSplitAmount(revenue.getAmount().toString());
+                pamentOrderUser.setSplitType("2");
+                splitList.add(pamentOrderUser);
+
+                DivisionRecord divisionRecord = new DivisionRecord();
+                divisionRecord.setUserType(2);
+                divisionRecord.setUserId(revenue.getUserId());
+                divisionRecord.setOrderId(order.getId());
+                divisionRecord.setMerOrderId(transaction_id);
+                divisionRecord.setSourceType(1);
+                divisionRecord.setAmount(revenue.getAmount());
+                divisionRecord.setMerchantNumber(agent.getMerchantNumber());
+                divisionRecord.setState(1);
+                divisionRecord.setCreateTime(new Date());
+                divisionRecordService.insert(divisionRecord);
+            }
+
+        }
+        complete.setSplitList(splitList);
+        TrhRequest<Complete> request = new TrhRequest();
+        InterfaceResponse execute = request.execute(complete, Complete.SERVICE_CODE);
+        if(!"0000".equals(execute.getResult())){
+            return ResultUtil.error(execute.getMsg());
+        }
+        JSONObject jsonObject = JSON.parseObject(execute.getResult());
+        String status = jsonObject.getString("status");
+        if("2".equals(status)){
+            return ResultUtil.error("失败");
+        }
+        if("0".equals(status)){
+            return ResultUtil.error("处理中");
+        }
+
+        //使用优惠券的情况,通过转账接口将优惠券的收入转到司机电子账簿
+        if(null != order.getCouponId()){
+            List<PlatformRechargeRecord> platformRechargeRecords = platformRechargeRecordService.selectList(new EntityWrapper<PlatformRechargeRecord>().eq("state", 2).last(" and balance > 0 order by payTime"));
+            Double discountedPrice = order.getDiscountedPrice();
+            Driver driver = driverService.selectById(order.getDriverId());
+            for (PlatformRechargeRecord platformRechargeRecord : platformRechargeRecords) {
+                if(discountedPrice == 0){
+                    break;
+                }
+
+                if(platformRechargeRecord.getBalance().compareTo(discountedPrice) >= 0){
+                    discountedPrice = 0D;
+                    platformRechargeRecord.setBalance(platformRechargeRecord.getBalance() - discountedPrice);
+                    platformRechargeRecordService.updateById(platformRechargeRecord);
+                }else{
+
+                }
+
+                Transfer transfer = new Transfer();
+                transfer.setDepositMerOrderId("6831518911582834611");
+                transfer.setToUserId(driver.getMerchantNumber());
+                transfer.setAmount(discountedPrice.toString());
+                transfer.setOrderName("");
+                transfer.setNotifyUrl("");
+                transfer.setParameter1(order.getId().toString());
+
+                TrhRequest<Transfer> request1 = new TrhRequest();
+                InterfaceResponse execute1 = request1.execute(transfer, Transfer.SERVICE_CODE);
+                if(!"0000".equals(execute1.getResult())){
+                    return ResultUtil.error(execute1.getMsg());
+                }
+                JSONObject jsonObject1 = JSON.parseObject(execute1.getResult());
+                String status1 = jsonObject1.getString("status");
+                if("2".equals(status1)){
+                    return ResultUtil.error("失败");
+                }
+                if("0".equals(status1)){
+                    return ResultUtil.error("处理中");
+                }
+            }
+        }
+
+
         return ResultUtil.success();
     }
+
+
+
+
+
+
+
 
 
     /**
@@ -1106,6 +1322,7 @@
 
                 //增加积分变动记录
                 AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                 accountChangeDetail.setUserType(2);
                 accountChangeDetail.setUserId(order.getDriverId());
                 accountChangeDetail.setCreateTime(new Date());
@@ -1126,6 +1343,7 @@
 
                 //增加积分变动记录
                 AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                 accountChangeDetail.setUserType(2);
                 accountChangeDetail.setUserId(order.getDriverId());
                 accountChangeDetail.setCreateTime(new Date());
@@ -1174,6 +1392,7 @@
                         if(num1 > 0){
                             Driver driver1 = driverService.selectById(appUser.getInviterId());
                             AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                            accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                             accountChangeDetail.setUserType(2);
                             accountChangeDetail.setUserId(driver1.getId());
                             accountChangeDetail.setType(1);
@@ -1220,6 +1439,7 @@
                                     revenueService.insert(revenue);
 
                                     AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                    accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                     accountChangeDetail.setUserType(2);
                                     accountChangeDetail.setUserId(driver1.getId());
                                     accountChangeDetail.setType(1);
@@ -1245,6 +1465,7 @@
                                     revenueService.insert(revenue);
 
                                     AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                    accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                     accountChangeDetail.setUserType(2);
                                     accountChangeDetail.setUserId(driver2.getId());
                                     accountChangeDetail.setType(1);
@@ -1270,6 +1491,7 @@
                                     revenueService.insert(revenue);
 
                                     AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                    accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                     accountChangeDetail.setUserType(2);
                                     accountChangeDetail.setUserId(driver3.getId());
                                     accountChangeDetail.setType(1);
@@ -1298,6 +1520,7 @@
                                     revenueService.insert(revenue);
 
                                     AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                    accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                     accountChangeDetail.setUserType(2);
                                     accountChangeDetail.setUserId(driver1.getId());
                                     accountChangeDetail.setType(1);
@@ -1323,6 +1546,7 @@
                                     revenueService.insert(revenue);
 
                                     AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                    accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                     accountChangeDetail.setUserType(2);
                                     accountChangeDetail.setUserId(driver2.getId());
                                     accountChangeDetail.setType(1);
@@ -1351,6 +1575,7 @@
                                 revenueService.insert(revenue);
 
                                 AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+                                accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
                                 accountChangeDetail.setUserType(2);
                                 accountChangeDetail.setUserId(driver1.getId());
                                 accountChangeDetail.setType(1);
@@ -1391,6 +1616,7 @@
         revenueService.insert(revenue);
 
         AccountChangeDetail accountChangeDetail = new AccountChangeDetail();
+        accountChangeDetail.setCode(System.currentTimeMillis() + UUIDUtil.getNumberRandom(3));
         accountChangeDetail.setUserType(2);
         accountChangeDetail.setUserId(driver.getId());
         accountChangeDetail.setType(1);
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/PlatformRechargeRecordServiceImpl.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/PlatformRechargeRecordServiceImpl.java
new file mode 100644
index 0000000..3e70fff
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/service/impl/PlatformRechargeRecordServiceImpl.java
@@ -0,0 +1,15 @@
+package com.supersavedriving.user.modular.system.service.impl;
+
+import com.baomidou.mybatisplus.service.impl.ServiceImpl;
+import com.supersavedriving.user.modular.system.dao.PlatformRechargeRecordMapper;
+import com.supersavedriving.user.modular.system.model.PlatformRechargeRecord;
+import com.supersavedriving.user.modular.system.service.IPlatformRechargeRecordService;
+import org.springframework.stereotype.Service;
+
+/**
+ * @author zhibing.pu
+ * @date 2023/5/6 14:11
+ */
+@Service
+public class PlatformRechargeRecordServiceImpl extends ServiceImpl<PlatformRechargeRecordMapper, PlatformRechargeRecord> implements IPlatformRechargeRecordService {
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/config/ChannelConfig.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/config/ChannelConfig.java
new file mode 100644
index 0000000..dc41f73
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/config/ChannelConfig.java
@@ -0,0 +1,60 @@
+package com.supersavedriving.user.modular.system.util.MallBook.config;
+
+import org.springframework.beans.factory.config.YamlPropertiesFactoryBean;
+import org.springframework.core.io.ClassPathResource;
+
+import java.util.Properties;
+
+/**
+ * @Author xiaogc
+ * @Date 2022/2/10 10:03
+ */
+public class ChannelConfig {
+    /**
+     * mallbook 测试环境地址
+     */
+    public static String payUrl;
+
+    /**
+     * 业务系统商户平台编号
+     */
+    public static String merchantNo;
+    /**
+     * 接口版本号,不同版本号触发不同接口业务
+     */
+    public static String version;
+    /*
+     * 渠道类型 HF:汇付
+     */
+    public static String channelType;
+
+    /**
+     * 商户平台私钥路径
+     */
+    public static String merchantPrivateKey;
+    /**
+     * mallbook公钥路径
+     */
+    public static String mallBookPublicKey;
+
+    static {
+        YamlPropertiesFactoryBean yamlProFb = new YamlPropertiesFactoryBean();
+        yamlProFb.setResources(new ClassPathResource("application.yaml"));
+        Properties properties = yamlProFb.getObject();
+        System.out.println("mallbook 参数配置初始化");
+        System.out.println("--------------------------------");
+        System.out.println("环境地址:" + properties.get("mallbook.pay_url"));
+        System.out.println("商户平台编号:" + properties.get("mallbook.merchant_no"));
+        System.out.println("接口版本号:" + properties.get("mallbook.version"));
+        System.out.println("渠道类型:" + properties.get("mallbook.channel_type"));
+        System.out.println("商户平台私钥:" + properties.get("mallbook.merchant_private_key"));
+        System.out.println("mallbook 公钥:" + properties.get("mallbook.mall_book_public_key"));
+        System.out.println("--------------------------------");
+        payUrl = properties.get("mallbook.pay_url").toString();
+        merchantNo = properties.get("mallbook.merchant_no").toString();
+        version = properties.get("mallbook.version").toString();
+        channelType = properties.get("mallbook.channel_type").toString();
+        merchantPrivateKey = properties.get("mallbook.merchant_private_key").toString();
+        mallBookPublicKey = properties.get("mallbook.mall_book_public_key").toString();
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Complete.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Complete.java
new file mode 100644
index 0000000..4d8c718
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Complete.java
@@ -0,0 +1,58 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+import java.util.List;
+
+public class Complete {
+    /**业务类型编号,必须和接口文档一致*/
+    public static String SERVICE_CODE = "complete";
+    //原支付请求订单号
+    private String originalMerOrderId;
+    //分账方列表
+    private List<PamentOrderUser> splitList;
+    //后台回调地址
+    private String notifyUrl;
+    //自定义参数1
+    private String parameter1;
+    //自定义参数2
+    private String parameter2;
+
+    public String getOriginalMerOrderId() {
+        return originalMerOrderId;
+    }
+
+    public void setOriginalMerOrderId(String originalMerOrderId) {
+        this.originalMerOrderId = originalMerOrderId;
+    }
+
+    public List<PamentOrderUser> getSplitList() {
+        return splitList;
+    }
+
+    public void setSplitList(List<PamentOrderUser> splitList) {
+        this.splitList = splitList;
+    }
+
+    public String getNotifyUrl() {
+        return notifyUrl;
+    }
+
+    public void setNotifyUrl(String notifyUrl) {
+        this.notifyUrl = notifyUrl;
+    }
+
+    public String getParameter1() {
+        return parameter1;
+    }
+
+    public void setParameter1(String parameter1) {
+        this.parameter1 = parameter1;
+    }
+
+    public String getParameter2() {
+        return parameter2;
+    }
+
+    public void setParameter2(String parameter2) {
+        this.parameter2 = parameter2;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceRequest.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceRequest.java
new file mode 100644
index 0000000..bd0eb13
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceRequest.java
@@ -0,0 +1,176 @@
+/**
+ *
+ */
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
+import com.supersavedriving.user.modular.system.util.MallBook.config.ChannelConfig;
+import com.supersavedriving.user.modular.system.util.MallBook.util.RSASignature;
+import com.supersavedriving.user.modular.system.util.MallBook.util.StringUtil;
+
+import java.io.Serializable;
+
+/**
+ * 接口请求包
+ *
+ */
+public class InterfaceRequest<T> implements Serializable {
+
+    /**
+     *
+     */
+    private static final long serialVersionUID = -8130938432046696213L;
+
+
+    /**
+     * 商户平台编号
+     */
+    private String merchantNo = ChannelConfig.merchantNo;
+
+    /**
+     * 接口版本号,不同版本号触发不同接口业务
+     */
+    private String version = ChannelConfig.version;
+    /*
+     * 渠道类型  HF:汇付
+     */
+    private String channelType = ChannelConfig.channelType;
+
+
+    /**
+     * 业务系统订单ID
+     */
+    private String merOrderId;
+
+    /**
+     * 签名
+     */
+    private String sign;
+
+    /**
+     * 业务类型编号
+     */
+    private String serverCode;
+
+    /**
+     * 业务参数,json格式
+     */
+    private String params;
+
+    /**
+     * 时间戳
+     */
+    private String date;
+
+
+    public String getChannelType() {
+        return channelType;
+    }
+
+    public void setChannelType(String channelType) {
+        this.channelType = channelType;
+    }
+
+    public String getMerOrderId() {
+        return merOrderId;
+    }
+
+    public void setMerOrderId(String merOrderId) {
+        this.merOrderId = merOrderId;
+    }
+
+    public String getMerchantNo() {
+        return merchantNo;
+    }
+
+    public void setMerchantNo(String merchantNo) {
+        this.merchantNo = merchantNo;
+    }
+
+    public String getSign() {
+        return sign;
+    }
+
+    public void setSign(String sign) {
+        this.sign = sign;
+    }
+
+    public String getServerCode() {
+        return serverCode;
+    }
+
+    public void setServerCode(String serverCode) {
+        this.serverCode = serverCode;
+    }
+
+    public String getParams() {
+        return params;
+    }
+
+    public void setParams(String params) {
+        this.params = params;
+    }
+
+    public String getDate() {
+        return date;
+    }
+
+    public void setDate(String date) {
+        this.date = date;
+    }
+
+    public String getVersion() {
+        return version;
+    }
+
+    public void setVersion(String version) {
+        this.version = version;
+    }
+
+
+    /**
+     * 签名顺序必须一致!!!
+     * 签名顺序必须一致!!!
+     * 签名顺序必须一致!!!
+     *  订单号 + 商户号 + 渠道类型 +  时间戳 + 业务参数json
+     * @return 待签名字符串
+     */
+    public String content() {
+        return StrUtil.builder()
+                .append(StringUtil.convertNull(merOrderId))
+                .append(StringUtil.convertNull(merchantNo))
+                .append(StringUtil.convertNull(channelType))
+                .append(StringUtil.convertNull(date))
+                .append(StringUtil.convertNull(params))
+                .toString();
+    }
+
+    public InterfaceRequest() {
+    }
+
+    public InterfaceRequest(T obj, String serverCode) {
+        this.merOrderId = IdUtil.fastSimpleUUID();
+        this.serverCode = serverCode;
+        this.date = System.currentTimeMillis() + "";
+        this.params = JSONUtil.toJsonStr(obj);
+        // todo 使用商户平台私钥生成sign,需要修改证书对应路径
+        this.sign = RSASignature.sign(content());
+    }
+
+
+    @Override
+    public String toString() {
+        return "InterfaceRequest{" +
+                "merOrderId='" + merOrderId + '\'' +
+                ", merchantNo='" + merchantNo + '\'' +
+                ", sign='" + sign + '\'' +
+                ", serverCode='" + serverCode + '\'' +
+                ", params='" + params + '\'' +
+                ", date='" + date + '\'' +
+                ", version='" + version + '\'' +
+                ", channelType='" + channelType + '\'' +
+                '}';
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceResponse.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceResponse.java
new file mode 100644
index 0000000..ac4211a
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/InterfaceResponse.java
@@ -0,0 +1,121 @@
+/**
+ *
+ */
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+
+import cn.hutool.core.util.StrUtil;
+import com.supersavedriving.user.modular.system.util.MallBook.util.StringUtil;
+
+import java.io.Serializable;
+
+
+public class InterfaceResponse implements Serializable {
+
+
+    /**
+     * 结果字符串,json格式
+     */
+    private String result;
+
+    /**
+     * 签名,由code+msg+date+result根据私钥生成, 如果有参数为null,签名串中应当做空字符串("")来处理
+     */
+    private String sign;
+
+    /**
+     * 结果代码
+     */
+    private String code;
+
+    /**
+     * 结果信息
+     */
+    private String msg;
+
+    /**
+     * 时间戳
+     */
+    private String date;
+
+    /**
+     * 接口版本号
+     */
+    private String version;
+
+    public String getResult() {
+        return result;
+    }
+
+    public void setResult(String result) {
+        this.result = result;
+    }
+
+    public String getSign() {
+        return sign;
+    }
+
+    public void setSign(String sign) {
+        this.sign = sign;
+    }
+
+    public String getCode() {
+        return code;
+    }
+
+    public void setCode(String code) {
+        this.code = code;
+    }
+
+    public String getMsg() {
+        return msg;
+    }
+
+    public void setMsg(String msg) {
+        this.msg = msg;
+    }
+
+    public String getDate() {
+        return date;
+    }
+
+    public void setDate(String date) {
+        this.date = date;
+    }
+
+    public String getVersion() {
+        return version;
+    }
+
+    public void setVersion(String version) {
+        this.version = version;
+    }
+
+    @Override
+    public String toString() {
+        return "InterfaceResponse{" +
+                "result='" + result + '\'' +
+                ", sign='" + sign + '\'' +
+                ", code='" + code + '\'' +
+                ", msg='" + msg + '\'' +
+                ", date='" + date + '\'' +
+                ", version='" + version + '\'' +
+                '}';
+    }
+
+    /**
+     * 签名顺序必须一致!!!
+     * 签名顺序必须一致!!!
+     * 签名顺序必须一致!!!
+     *  结果代码 + 结果信息 + 渠道类型 +  时间戳 + 结果字符串json
+     * @return 待签名字符串
+     */
+    public String content() {
+        return StrUtil.builder()
+                .append(StringUtil.convertNull(code))
+                .append(StringUtil.convertNull(msg))
+                .append(StringUtil.convertNull(date))
+                .append(StringUtil.convertNull(result))
+                .toString();
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PamentOrderUser.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PamentOrderUser.java
new file mode 100644
index 0000000..67cea1d
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PamentOrderUser.java
@@ -0,0 +1,46 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+public class PamentOrderUser {
+
+    /**
+     * 分账方会员ID(必填)
+     */
+    private  String splitUserId;
+
+    /**
+     * 分账金额(必填)
+     */
+    private String splitAmount;
+
+    /**
+     * 分账类型(必填)
+     * 0:收单金额(收款人)
+     * 1:分账金额
+     * 2:佣金
+     */
+    private String splitType;
+
+    public String getSplitUserId() {
+        return splitUserId;
+    }
+
+    public void setSplitUserId(String splitUserId) {
+        this.splitUserId = splitUserId;
+    }
+
+    public String getSplitAmount() {
+        return splitAmount;
+    }
+
+    public void setSplitAmount(String splitAmount) {
+        this.splitAmount = splitAmount;
+    }
+
+    public String getSplitType() {
+        return splitType;
+    }
+
+    public void setSplitType(String splitType) {
+        this.splitType = splitType;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrder.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrder.java
new file mode 100644
index 0000000..08fe408
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrder.java
@@ -0,0 +1,293 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+import java.util.List;
+
+public class PaymentOrder {
+    /**业务类型编号,必须和接口文档一致*/
+    public static String SERVICE_CODE = "paymentOrder";
+    /**
+     * 业务订单号(必填)
+     */
+    private String bizOrderId;
+
+    /**
+     * 交易金额(必填)
+     */
+    private String amount;
+
+    /**
+     * 付款人
+     */
+    private String payerUserName;
+
+    /**
+     * 收款人会员ID(必填)
+     */
+    private String payeeUserId;
+
+    /**
+     * 订单名称(必填)
+     */
+    private String orderName;
+
+    /**
+     * 支付类型(必填)
+     */
+    private String payType;
+
+    /**
+     * 交易类型(必填)
+     */
+    private String transferType;
+
+    /**
+     * 订单过期时间
+     */
+    private String expire;
+
+    /**
+     * 微信或支付宝的appid
+     */
+    private String appid;
+
+    /**
+     * 微信或支付宝用户id
+     */
+    private String openid;
+
+    /**
+     * 终端IP(必填)
+     */
+    private String terminalIp;
+
+    /**
+     * 分账方列表(必填)
+     */
+    private List<PamentOrderUser> splitList;
+
+    /**
+     * 商品列表(必填)
+     */
+    private List<PaymentOrderGood> goodsDetail;
+
+    /**
+     * 前台回调地址(必填)
+     */
+    private String frontUrl;
+
+    /**
+     * 后台回调地址(必填)
+     */
+    private String notifyUrl;
+
+    /**
+     * 自定义参数1
+     */
+    private String parameter1;
+
+    /**
+     * 自定义参数2
+     */
+    private String parameter2;
+    /*
+     * 是否异步分账
+     */
+    private String asynSplitFlag;
+
+    /**
+     * 付款方子商户编号
+     */
+    private String payerUserId;
+
+    /**
+     * 银行编码
+     */
+    private String bankCode;
+
+    /**
+     * 银行卡类型
+     */
+    private String cardType;
+
+    /**
+     * 快捷卡唯一标识
+     */
+    private String tokenNo;
+
+
+    public String getPayerUserId() {
+        return payerUserId;
+    }
+
+    public void setPayerUserId(String payerUserId) {
+        this.payerUserId = payerUserId;
+    }
+
+    public String getBankCode() {
+        return bankCode;
+    }
+
+    public void setBankCode(String bankCode) {
+        this.bankCode = bankCode;
+    }
+
+    public String getCardType() {
+        return cardType;
+    }
+
+    public void setCardType(String cardType) {
+        this.cardType = cardType;
+    }
+
+    public String getTokenNo() {
+        return tokenNo;
+    }
+
+    public void setTokenNo(String tokenNo) {
+        this.tokenNo = tokenNo;
+    }
+
+    public String getAsynSplitFlag() {
+        return asynSplitFlag;
+    }
+
+    public void setAsynSplitFlag(String asynSplitFlag) {
+        this.asynSplitFlag = asynSplitFlag;
+    }
+
+    public String getBizOrderId() {
+        return bizOrderId;
+    }
+
+    public void setBizOrderId(String bizOrderId) {
+        this.bizOrderId = bizOrderId;
+    }
+
+    public String getAmount() {
+        return amount;
+    }
+
+    public void setAmount(String amount) {
+        this.amount = amount;
+    }
+
+    public String getPayerUserName() {
+        return payerUserName;
+    }
+
+    public void setPayerUserName(String payerUserName) {
+        this.payerUserName = payerUserName;
+    }
+
+    public String getPayeeUserId() {
+        return payeeUserId;
+    }
+
+    public void setPayeeUserId(String payeeUserId) {
+        this.payeeUserId = payeeUserId;
+    }
+
+    public String getOrderName() {
+        return orderName;
+    }
+
+    public void setOrderName(String orderName) {
+        this.orderName = orderName;
+    }
+
+    public String getPayType() {
+        return payType;
+    }
+
+    public void setPayType(String payType) {
+        this.payType = payType;
+    }
+
+    public String getTransferType() {
+        return transferType;
+    }
+
+    public void setTransferType(String transferType) {
+        this.transferType = transferType;
+    }
+
+    public String getExpire() {
+        return expire;
+    }
+
+    public void setExpire(String expire) {
+        this.expire = expire;
+    }
+
+    public String getAppid() {
+        return appid;
+    }
+
+    public void setAppid(String appid) {
+        this.appid = appid;
+    }
+
+    public String getOpenid() {
+        return openid;
+    }
+
+    public void setOpenid(String openid) {
+        this.openid = openid;
+    }
+
+    public String getTerminalIp() {
+        return terminalIp;
+    }
+
+    public void setTerminalIp(String terminalIp) {
+        this.terminalIp = terminalIp;
+    }
+
+    public List<PamentOrderUser> getSplitList() {
+        return splitList;
+    }
+
+    public void setSplitList(List<PamentOrderUser> splitList) {
+        this.splitList = splitList;
+    }
+
+    public List<PaymentOrderGood> getGoodsDetail() {
+        return goodsDetail;
+    }
+
+    public void setGoodsDetail(List<PaymentOrderGood> goodsDetail) {
+        this.goodsDetail = goodsDetail;
+    }
+
+    public String getFrontUrl() {
+        return frontUrl;
+    }
+
+    public void setFrontUrl(String frontUrl) {
+        this.frontUrl = frontUrl;
+    }
+
+    public String getNotifyUrl() {
+        return notifyUrl;
+    }
+
+    public void setNotifyUrl(String notifyUrl) {
+        this.notifyUrl = notifyUrl;
+    }
+
+    public String getParameter1() {
+        return parameter1;
+    }
+
+    public void setParameter1(String parameter1) {
+        this.parameter1 = parameter1;
+    }
+
+    public String getParameter2() {
+        return parameter2;
+    }
+
+    public void setParameter2(String parameter2) {
+        this.parameter2 = parameter2;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrderGood.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrderGood.java
new file mode 100644
index 0000000..5ec7180
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/PaymentOrderGood.java
@@ -0,0 +1,48 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+public class PaymentOrderGood {
+
+    /** 商品编号 */
+    private String goodsId;
+
+    /** 商品名称,必填 */
+    private String goodsName;
+
+    /** 商品数量 */
+    private String quantity;
+
+    /** 商品价格 */
+    private String price;
+
+    public String getGoodsId() {
+        return goodsId;
+    }
+
+    public void setGoodsId(String goodsId) {
+        this.goodsId = goodsId;
+    }
+
+    public String getGoodsName() {
+        return goodsName;
+    }
+
+    public void setGoodsName(String goodsName) {
+        this.goodsName = goodsName;
+    }
+
+    public String getQuantity() {
+        return quantity;
+    }
+
+    public void setQuantity(String quantity) {
+        this.quantity = quantity;
+    }
+
+    public String getPrice() {
+        return price;
+    }
+
+    public void setPrice(String price) {
+        this.price = price;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Receive.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Receive.java
new file mode 100644
index 0000000..3f82606
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/Receive.java
@@ -0,0 +1,102 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+import java.util.List;
+
+/**
+ * 确认收货信息参数
+ */
+public class Receive {
+    /**业务类型编号,必须和接口文档一致*/
+    public static String SERVICE_CODE = "receive";
+    /**
+     * 原支付请求订单号(必填)
+     */
+    private String originalMerOrderId;
+    /**
+     * 异步分账订单号(多次异步确认订单进行确认收货时必传)
+     */
+    private String asynMerOrderId;
+
+    /**
+     * 确认收货总额(必填)
+     * 必须大于0
+     * 确认收货总额=总确认分账金额
+     */
+    private String rcvAmount;
+
+    /**
+     * 分账方列表(必填)
+     */
+    private List<ReceiveUser> splitList;
+
+    /**
+     * 商品列表
+     */
+    private List<ReceiveGood> goodsDetail;
+    /**
+     * 自定义参数1
+     */
+    private String parameter1;
+
+    /**
+     * 自定义参数2
+     */
+    private String parameter2;
+
+    public String getOriginalMerOrderId() {
+        return originalMerOrderId;
+    }
+
+    public void setOriginalMerOrderId(String originalMerOrderId) {
+        this.originalMerOrderId = originalMerOrderId;
+    }
+
+    public String getAsynMerOrderId() {
+        return asynMerOrderId;
+    }
+
+    public void setAsynMerOrderId(String asynMerOrderId) {
+        this.asynMerOrderId = asynMerOrderId;
+    }
+
+    public String getRcvAmount() {
+        return rcvAmount;
+    }
+
+    public void setRcvAmount(String rcvAmount) {
+        this.rcvAmount = rcvAmount;
+    }
+
+    public List<ReceiveUser> getSplitList() {
+        return splitList;
+    }
+
+    public void setSplitList(List<ReceiveUser> splitList) {
+        this.splitList = splitList;
+    }
+
+    public List<ReceiveGood> getGoodsDetail() {
+        return goodsDetail;
+    }
+
+    public void setGoodsDetail(List<ReceiveGood> goodsDetail) {
+        this.goodsDetail = goodsDetail;
+    }
+
+    public String getParameter1() {
+        return parameter1;
+    }
+
+    public void setParameter1(String parameter1) {
+        this.parameter1 = parameter1;
+    }
+
+    public String getParameter2() {
+        return parameter2;
+    }
+
+    public void setParameter2(String parameter2) {
+        this.parameter2 = parameter2;
+    }
+
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveGood.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveGood.java
new file mode 100644
index 0000000..a9108ac
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveGood.java
@@ -0,0 +1,48 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+public class ReceiveGood {
+
+    /** 商品编号 */
+    private String goodsId;
+
+    /** 商品名称,必填 */
+    private String goodsName;
+
+    /** 商品数量 */
+    private String quantity;
+
+    /** 商品价格 */
+    private String price;
+
+    public String getGoodsId() {
+        return goodsId;
+    }
+
+    public void setGoodsId(String goodsId) {
+        this.goodsId = goodsId;
+    }
+
+    public String getGoodsName() {
+        return goodsName;
+    }
+
+    public void setGoodsName(String goodsName) {
+        this.goodsName = goodsName;
+    }
+
+    public String getQuantity() {
+        return quantity;
+    }
+
+    public void setQuantity(String quantity) {
+        this.quantity = quantity;
+    }
+
+    public String getPrice() {
+        return price;
+    }
+
+    public void setPrice(String price) {
+        this.price = price;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveUser.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveUser.java
new file mode 100644
index 0000000..58abff3
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/model/ReceiveUser.java
@@ -0,0 +1,27 @@
+package com.supersavedriving.user.modular.system.util.MallBook.model;
+
+
+public class ReceiveUser {
+
+    /** 分账方会员ID,必填 */
+    private String splitUserId;
+
+    /** 确认分账金额,必填 */
+    private String rcvSplitAmount;
+
+    public String getSplitUserId() {
+        return splitUserId;
+    }
+
+    public void setSplitUserId(String splitUserId) {
+        this.splitUserId = splitUserId;
+    }
+
+    public String getRcvSplitAmount() {
+        return rcvSplitAmount;
+    }
+
+    public void setRcvSplitAmount(String rcvSplitAmount) {
+        this.rcvSplitAmount = rcvSplitAmount;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Base64.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Base64.java
new file mode 100644
index 0000000..f685ee7
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Base64.java
@@ -0,0 +1,288 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+/**
+ * @Author xiaogc
+ * @Date 2021/12/21 14:23
+ */
+public class Base64 {
+    static private final int BASELENGTH = 128;
+    static private final int LOOKUPLENGTH = 64;
+    static private final int TWENTYFOURBITGROUP = 24;
+    static private final int EIGHTBIT = 8;
+    static private final int SIXTEENBIT = 16;
+    static private final int FOURBYTE = 4;
+    static private final int SIGN = -128;
+    static private final char PAD = '=';
+    static private final boolean fDebug = false;
+    static final private byte[] base64Alphabet = new byte[BASELENGTH];
+    static final private char[] lookUpBase64Alphabet = new char[LOOKUPLENGTH];
+
+    static {
+        for (int i = 0; i < BASELENGTH; ++i) {
+            base64Alphabet[i] = -1;
+        }
+        for (int i = 'Z'; i >= 'A'; i--) {
+            base64Alphabet[i] = (byte) (i - 'A');
+        }
+        for (int i = 'z'; i >= 'a'; i--) {
+            base64Alphabet[i] = (byte) (i - 'a' + 26);
+        }
+
+        for (int i = '9'; i >= '0'; i--) {
+            base64Alphabet[i] = (byte) (i - '0' + 52);
+        }
+
+        base64Alphabet['+'] = 62;
+        base64Alphabet['/'] = 63;
+
+        for (int i = 0; i <= 25; i++) {
+            lookUpBase64Alphabet[i] = (char) ('A' + i);
+        }
+
+        for (int i = 26, j = 0; i <= 51; i++, j++) {
+            lookUpBase64Alphabet[i] = (char) ('a' + j);
+        }
+
+        for (int i = 52, j = 0; i <= 61; i++, j++) {
+            lookUpBase64Alphabet[i] = (char) ('0' + j);
+        }
+        lookUpBase64Alphabet[62] = (char) '+';
+        lookUpBase64Alphabet[63] = (char) '/';
+
+    }
+
+    private static boolean isWhiteSpace(char octect) {
+        return (octect == 0x20 || octect == 0xd || octect == 0xa || octect == 0x9);
+    }
+
+    private static boolean isPad(char octect) {
+        return (octect == PAD);
+    }
+
+    private static boolean isData(char octect) {
+        return (octect < BASELENGTH && base64Alphabet[octect] != -1);
+    }
+
+    /**
+     * Encodes hex octects into Base64
+     *
+     * @param binaryData
+     *            Array containing binaryData
+     * @return Encoded Base64 array
+     */
+    public static String encode(byte[] binaryData) {
+
+        if (binaryData == null) {
+            return null;
+        }
+
+        int lengthDataBits = binaryData.length * EIGHTBIT;
+        if (lengthDataBits == 0) {
+            return "";
+        }
+
+        int fewerThan24bits = lengthDataBits % TWENTYFOURBITGROUP;
+        int numberTriplets = lengthDataBits / TWENTYFOURBITGROUP;
+        int numberQuartet = fewerThan24bits != 0 ? numberTriplets + 1
+                : numberTriplets;
+        char encodedData[] = null;
+
+        encodedData = new char[numberQuartet * 4];
+
+        byte k = 0, l = 0, b1 = 0, b2 = 0, b3 = 0;
+
+        int encodedIndex = 0;
+        int dataIndex = 0;
+        if (fDebug) {
+            System.out.println("number of triplets = " + numberTriplets);
+        }
+
+        for (int i = 0; i < numberTriplets; i++) {
+            b1 = binaryData[dataIndex++];
+            b2 = binaryData[dataIndex++];
+            b3 = binaryData[dataIndex++];
+
+            if (fDebug) {
+                System.out.println("b1= " + b1 + ", b2= " + b2 + ", b3= " + b3);
+            }
+
+            l = (byte) (b2 & 0x0f);
+            k = (byte) (b1 & 0x03);
+
+            byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)
+                    : (byte) ((b1) >> 2 ^ 0xc0);
+            byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4)
+                    : (byte) ((b2) >> 4 ^ 0xf0);
+            byte val3 = ((b3 & SIGN) == 0) ? (byte) (b3 >> 6)
+                    : (byte) ((b3) >> 6 ^ 0xfc);
+
+            if (fDebug) {
+                System.out.println("val2 = " + val2);
+                System.out.println("k4   = " + (k << 4));
+                System.out.println("vak  = " + (val2 | (k << 4)));
+            }
+
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[(l << 2) | val3];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[b3 & 0x3f];
+        }
+
+        // form integral number of 6-bit groups
+        if (fewerThan24bits == EIGHTBIT) {
+            b1 = binaryData[dataIndex];
+            k = (byte) (b1 & 0x03);
+            if (fDebug) {
+                System.out.println("b1=" + b1);
+                System.out.println("b1<<2 = " + (b1 >> 2));
+            }
+            byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)
+                    : (byte) ((b1) >> 2 ^ 0xc0);
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[k << 4];
+            encodedData[encodedIndex++] = PAD;
+            encodedData[encodedIndex++] = PAD;
+        } else if (fewerThan24bits == SIXTEENBIT) {
+            b1 = binaryData[dataIndex];
+            b2 = binaryData[dataIndex + 1];
+            l = (byte) (b2 & 0x0f);
+            k = (byte) (b1 & 0x03);
+
+            byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)
+                    : (byte) ((b1) >> 2 ^ 0xc0);
+            byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4)
+                    : (byte) ((b2) >> 4 ^ 0xf0);
+
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)];
+            encodedData[encodedIndex++] = lookUpBase64Alphabet[l << 2];
+            encodedData[encodedIndex++] = PAD;
+        }
+
+        return new String(encodedData);
+    }
+
+    /**
+     * Decodes Base64 data into octects
+     *
+     * @param encoded
+     *            string containing Base64 data
+     * @return Array containind decoded data.
+     */
+    public static byte[] decode(String encoded) {
+
+        if (encoded == null) {
+            return null;
+        }
+
+        char[] base64Data = encoded.toCharArray();
+        // remove white spaces
+        int len = removeWhiteSpace(base64Data);
+
+        if (len % FOURBYTE != 0) {
+            return null;// should be divisible by four
+        }
+
+        int numberQuadruple = (len / FOURBYTE);
+
+        if (numberQuadruple == 0) {
+            return new byte[0];
+        }
+
+        byte decodedData[] = null;
+        byte b1 = 0, b2 = 0, b3 = 0, b4 = 0;
+        char d1 = 0, d2 = 0, d3 = 0, d4 = 0;
+
+        int i = 0;
+        int encodedIndex = 0;
+        int dataIndex = 0;
+        decodedData = new byte[(numberQuadruple) * 3];
+
+        for (; i < numberQuadruple - 1; i++) {
+
+            if (!isData((d1 = base64Data[dataIndex++]))
+                    || !isData((d2 = base64Data[dataIndex++]))
+                    || !isData((d3 = base64Data[dataIndex++]))
+                    || !isData((d4 = base64Data[dataIndex++]))) {
+                return null;
+            }// if found "no data" just return null
+
+            b1 = base64Alphabet[d1];
+            b2 = base64Alphabet[d2];
+            b3 = base64Alphabet[d3];
+            b4 = base64Alphabet[d4];
+
+            decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);
+            decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));
+            decodedData[encodedIndex++] = (byte) (b3 << 6 | b4);
+        }
+
+        if (!isData((d1 = base64Data[dataIndex++]))
+                || !isData((d2 = base64Data[dataIndex++]))) {
+            return null;// if found "no data" just return null
+        }
+
+        b1 = base64Alphabet[d1];
+        b2 = base64Alphabet[d2];
+
+        d3 = base64Data[dataIndex++];
+        d4 = base64Data[dataIndex++];
+        if (!isData((d3)) || !isData((d4))) {// Check if they are PAD characters
+            if (isPad(d3) && isPad(d4)) {
+                if ((b2 & 0xf) != 0)// last 4 bits should be zero
+                {
+                    return null;
+                }
+                byte[] tmp = new byte[i * 3 + 1];
+                System.arraycopy(decodedData, 0, tmp, 0, i * 3);
+                tmp[encodedIndex] = (byte) (b1 << 2 | b2 >> 4);
+                return tmp;
+            } else if (!isPad(d3) && isPad(d4)) {
+                b3 = base64Alphabet[d3];
+                if ((b3 & 0x3) != 0)// last 2 bits should be zero
+                {
+                    return null;
+                }
+                byte[] tmp = new byte[i * 3 + 2];
+                System.arraycopy(decodedData, 0, tmp, 0, i * 3);
+                tmp[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);
+                tmp[encodedIndex] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));
+                return tmp;
+            } else {
+                return null;
+            }
+        } else { // No PAD e.g 3cQl
+            b3 = base64Alphabet[d3];
+            b4 = base64Alphabet[d4];
+            decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);
+            decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));
+            decodedData[encodedIndex++] = (byte) (b3 << 6 | b4);
+
+        }
+
+        return decodedData;
+    }
+
+    /**
+     * remove WhiteSpace from MIME containing encoded Base64 data.
+     *
+     * @param data
+     *            the byte array of base64 data (with WS)
+     * @return the new length
+     */
+    private static int removeWhiteSpace(char[] data) {
+        if (data == null) {
+            return 0;
+        }
+
+        // count characters that's not whitespace
+        int newSize = 0;
+        int len = data.length;
+        for (int i = 0; i < len; i++) {
+            if (!isWhiteSpace(data[i])) {
+                data[newSize++] = data[i];
+            }
+        }
+        return newSize;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/CacheUtils.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/CacheUtils.java
new file mode 100644
index 0000000..0c0f81c
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/CacheUtils.java
@@ -0,0 +1,39 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+import cn.hutool.cache.CacheUtil;
+import cn.hutool.cache.impl.TimedCache;
+
+/**
+ * @author linqy
+ * 缓存工具类,生产建议使用其他缓存中间件
+ */
+public class CacheUtils {
+    private static final TimedCache<String, String> TIMED_CACHE = CacheUtil.newTimedCache(5000);
+
+    static {
+        /** 每1s检查一次过期 */
+        TIMED_CACHE.schedulePrune(1000);
+    }
+
+    /**
+     * 存入键值对,提供消逝时间
+     *
+     * @param key
+     * @param value
+     * @param timeout
+     */
+    public static void put(String key, String value, Long timeout) {
+        /** 设置消逝时间 */
+        TIMED_CACHE.put(key, value, timeout);
+    }
+
+    /**
+     * 每次重新get一次缓存,均会重新刷新消逝时间
+     * @param key
+     * @return
+     */
+    public static String get(String key) {
+        return TIMED_CACHE.get(key);
+    }
+
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSAEncryptGeneration.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSAEncryptGeneration.java
new file mode 100644
index 0000000..4686fee
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSAEncryptGeneration.java
@@ -0,0 +1,65 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+import java.io.BufferedWriter;
+import java.io.FileWriter;
+import java.security.KeyPair;
+import java.security.KeyPairGenerator;
+import java.security.NoSuchAlgorithmException;
+import java.security.SecureRandom;
+import java.security.interfaces.RSAPrivateKey;
+import java.security.interfaces.RSAPublicKey;
+
+/**
+ * 公私钥代码生成
+ * @Author xiaogc
+ * @Date 2021/12/21 14:22
+ */
+public class RSAEncryptGeneration {
+
+    public static void main(String[] args) {
+        // 生成一对公私钥到指定路径下  .pfx私钥 .cer公钥
+        RSAEncryptGeneration.genKeyPair("D:\\tools");
+    }
+    /**
+     * 随机生成密钥对
+     */
+    public static void genKeyPair(String filePath) {
+        // KeyPairGenerator类用于生成公钥和私钥对,基于RSA算法生成对象
+        KeyPairGenerator keyPairGen = null;
+        try {
+            keyPairGen = KeyPairGenerator.getInstance("RSA");
+        } catch (NoSuchAlgorithmException e) {
+            e.printStackTrace();
+        }
+        // 初始化密钥对生成器,密钥大小为96-1024位
+        keyPairGen.initialize(1024, new SecureRandom());
+        // 生成一个密钥对,保存在keyPair中
+        KeyPair keyPair = keyPairGen.generateKeyPair();
+        // 得到私钥
+        RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();
+        // 得到公钥
+        RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();
+        try {
+            // 得到公钥字符串
+            String publicKeyString = Base64.encode(publicKey.getEncoded());
+            System.out.println("公钥字符串:"+publicKeyString);
+            // 得到私钥字符串
+            String privateKeyString = Base64.encode(privateKey.getEncoded());
+            System.out.println("私钥字符串:"+privateKeyString);
+            // 将密钥对写入到文件  .pfx私钥 .cer公钥
+            FileWriter pubfw = new FileWriter(filePath + "/merchant_no.cer");
+            FileWriter prifw = new FileWriter(filePath + "/merchant_no.pfx");
+            BufferedWriter pubbw = new BufferedWriter(pubfw);
+            BufferedWriter pribw = new BufferedWriter(prifw);
+            pubbw.write(publicKeyString);
+            pribw.write(privateKeyString);
+            pubbw.flush();
+            pubbw.close();
+            pubfw.close();
+            pribw.flush();
+            pribw.close();
+            prifw.close();
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSASignature.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSASignature.java
new file mode 100644
index 0000000..74a3440
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/RSASignature.java
@@ -0,0 +1,118 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+
+import com.supersavedriving.user.modular.system.util.MallBook.config.ChannelConfig;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.io.BufferedReader;
+import java.io.FileReader;
+import java.io.IOException;
+import java.security.KeyFactory;
+import java.security.PrivateKey;
+import java.security.PublicKey;
+import java.security.spec.PKCS8EncodedKeySpec;
+import java.security.spec.X509EncodedKeySpec;
+
+/**
+ * @author RSA签名验签类
+ */
+public class RSASignature {
+
+    public static Logger logger = LoggerFactory.getLogger(RSASignature.class);
+
+    /**
+     * 签名算法
+     */
+    public static final String SIGN_ALGORITHMS = "SHA1WithRSA";
+
+
+    /**
+     * 商户平台私钥签名
+     *
+     * @param content
+     * @return
+     */
+    public static String sign(String content) {
+        try {
+            String privateKey = ChannelConfig.merchantPrivateKey;
+            PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(Base64.decode(privateKey));
+            KeyFactory keyf = KeyFactory.getInstance("RSA");
+            PrivateKey priKey = keyf.generatePrivate(priPKCS8);
+            java.security.Signature signature = java.security.Signature.getInstance(SIGN_ALGORITHMS);
+            signature.initSign(priKey);
+            signature.update(content.getBytes());
+            byte[] signed = signature.sign();
+            return Base64.encode(signed);
+        } catch (Exception e) {
+            logger.error("签名失败{}", e);
+        }
+        return null;
+    }
+
+
+    /**
+     * 读取证书
+     *
+     * @param filePath 证书文件路径
+     */
+    public static String loadKey(String filePath) throws Exception {
+        try (BufferedReader br = new BufferedReader(new FileReader(filePath))) {
+            String readLine;
+            StringBuilder sb = new StringBuilder();
+            while ((readLine = br.readLine()) != null) {
+                sb.append(readLine);
+            }
+            return sb.toString();
+        } catch (IOException e) {
+            throw new Exception("私钥数据读取错误");
+        } catch (NullPointerException e) {
+            throw new Exception("私钥输入流为空");
+        }
+    }
+
+
+    /**
+     * mallbook公钥验签
+     *
+     * @param content 待签名数据
+     * @param sign    签名值
+     * @return false 验签失败 true 成功
+     */
+    public static boolean validate(String content, String sign) {
+        boolean verify = false;
+        try {
+            String publicKey = ChannelConfig.mallBookPublicKey;
+            verify = RSASignature.doCheck(content, sign, publicKey, "utf-8");
+        } catch (Exception e) {
+            logger.error("验签失败:{}", e);
+        }
+        return verify;
+    }
+
+
+    /**
+     * RSA验签
+     *
+     * @param content   待签名数据
+     * @param sign      签名值
+     * @param publicKey 分配给开发商公钥
+     * @param encode    字符集编码
+     * @return 布尔值
+     */
+    public static boolean doCheck(String content, String sign, String publicKey, String encode) {
+        try {
+            KeyFactory keyFactory = KeyFactory.getInstance("RSA");
+            byte[] encodedKey = Base64.decode(publicKey);
+            PublicKey pubKey = keyFactory.generatePublic(new X509EncodedKeySpec(encodedKey));
+            java.security.Signature signature = java.security.Signature.getInstance(SIGN_ALGORITHMS);
+            signature.initVerify(pubKey);
+            signature.update(content.getBytes(encode));
+            return signature.verify(Base64.decode(sign));
+        } catch (Exception e) {
+            logger.error("验签失败{}", e);
+        }
+        return false;
+    }
+
+}
\ No newline at end of file
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/StringUtil.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/StringUtil.java
new file mode 100644
index 0000000..bc465c1
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/StringUtil.java
@@ -0,0 +1,23 @@
+
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+import cn.hutool.core.util.StrUtil;
+
+
+public class StringUtil extends StrUtil {
+
+    /**
+     * null转为空字符串
+     *
+     * @param str
+     * @return
+     */
+    public static String convertNull(String str) {
+        if (str == null) {
+            return "";
+        }
+        return str;
+    }
+
+
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Transfer.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Transfer.java
new file mode 100644
index 0000000..1101797
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/Transfer.java
@@ -0,0 +1,76 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+public class Transfer {
+    /**业务类型编号,必须和接口文档一致*/
+    public static String SERVICE_CODE = "transfer";
+    //充值订单号
+    private String depositMerOrderId;
+    //收款方子商户号
+    private String toUserId;
+    //转账金额
+    private String amount;
+    //订单信息
+    private String orderName;
+    //后台回调地址
+    private String notifyUrl;
+    //自定义参数1
+    private String parameter1;
+    //自定义参数2
+    private String parameter2;
+
+    public String getDepositMerOrderId() {
+        return depositMerOrderId;
+    }
+
+    public void setDepositMerOrderId(String depositMerOrderId) {
+        this.depositMerOrderId = depositMerOrderId;
+    }
+
+    public String getToUserId() {
+        return toUserId;
+    }
+
+    public void setToUserId(String toUserId) {
+        this.toUserId = toUserId;
+    }
+
+    public String getAmount() {
+        return amount;
+    }
+
+    public void setAmount(String amount) {
+        this.amount = amount;
+    }
+
+    public String getOrderName() {
+        return orderName;
+    }
+
+    public void setOrderName(String orderName) {
+        this.orderName = orderName;
+    }
+
+    public String getNotifyUrl() {
+        return notifyUrl;
+    }
+
+    public void setNotifyUrl(String notifyUrl) {
+        this.notifyUrl = notifyUrl;
+    }
+
+    public String getParameter1() {
+        return parameter1;
+    }
+
+    public void setParameter1(String parameter1) {
+        this.parameter1 = parameter1;
+    }
+
+    public String getParameter2() {
+        return parameter2;
+    }
+
+    public void setParameter2(String parameter2) {
+        this.parameter2 = parameter2;
+    }
+}
diff --git a/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/TrhRequest.java b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/TrhRequest.java
new file mode 100644
index 0000000..dcff13d
--- /dev/null
+++ b/user/guns-admin/src/main/java/com/supersavedriving/user/modular/system/util/MallBook/util/TrhRequest.java
@@ -0,0 +1,31 @@
+package com.supersavedriving.user.modular.system.util.MallBook.util;
+
+import cn.hutool.core.bean.BeanUtil;
+import cn.hutool.core.exceptions.ValidateException;
+import cn.hutool.http.HttpUtil;
+import cn.hutool.json.JSONUtil;
+import com.supersavedriving.user.modular.system.util.MallBook.config.ChannelConfig;
+import com.supersavedriving.user.modular.system.util.MallBook.model.InterfaceRequest;
+import com.supersavedriving.user.modular.system.util.MallBook.model.InterfaceResponse;
+
+/**
+ * @Author xiaogc
+ * @Date 2022/1/24 13:45
+ */
+public class TrhRequest<T> {
+
+    public InterfaceResponse execute(T t, String serverCode) {
+        InterfaceRequest<T> request = new InterfaceRequest(t, serverCode);
+        System.out.println("mallbook请求参数:" + JSONUtil.toJsonStr(request));
+        String result = HttpUtil.post(ChannelConfig.payUrl, BeanUtil.beanToMap(request));
+        System.out.println("mallbook响应参数:" + result);
+        InterfaceResponse response = JSONUtil.toBean(result, InterfaceResponse.class);
+        boolean verify = RSASignature.validate(response.content(), response.getSign());
+        if (!verify) {
+            throw new ValidateException("签名验证失败");
+        } else {
+            System.out.printf("签名验证通过");
+        }
+        return response;
+    }
+}
diff --git a/user/guns-admin/src/main/resources/application.yml b/user/guns-admin/src/main/resources/application.yml
index 3cdee0e..b050295 100644
--- a/user/guns-admin/src/main/resources/application.yml
+++ b/user/guns-admin/src/main/resources/application.yml
@@ -13,8 +13,8 @@
   application:
     name: user-server
   profiles:
-#    active: dev
-    active: produce
+    active: dev
+#    active: produce
   mvc:
     static-path-pattern: /static/**
     view:
@@ -55,8 +55,8 @@
   datasource:
     url: jdbc:mysql://127.0.0.1:3306/super_save_driving?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=Asia/Shanghai
     username: root
-    password: f4OfRjqoN3jSiNGiUoiNsQdOBtCOKYRj
-#    password: 123456
+#    password: f4OfRjqoN3jSiNGiUoiNsQdOBtCOKYRj
+    password: 123456
     db-name: guns #用来搜集数据库的所有表
     filters: wall,mergeStat
 
@@ -130,5 +130,24 @@
 spring:
   data:
     mongodb:
-      uri: mongodb://root:CEtyLdKjPk0yeHNo@127.0.0.1:27017/admin
-#      uri: mongodb://127.0.0.1:27017/admin
\ No newline at end of file
+#      uri: mongodb://root:CEtyLdKjPk0yeHNo@127.0.0.1:27017/admin
+      uri: mongodb://127.0.0.1:27017/admin
+
+
+#  mallbook 调起接口参数配置
+mallbook:
+  # pay_url:mallbook接口地址    测试环境: http://ld.mallbook.cn:12000/api   生产环境:https://cloudpay.mallbook.cn/api
+  pay_url: http://ld.mallbook.cn:12000/api
+  # merchant_no 业务系统商户平台编号,需替换为mallbook工作人员提供的商户编号
+  merchant_no:  需要替换内容
+  # version 接口版本号
+  version: 1.0.0
+  # channel_type 渠道类型 HF:汇付
+  channel_type: HF
+  # merchant_private_key 商户平台私钥,需要替换成商户平台自己生成的私钥
+  merchant_private_key: MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAIoGARvX6k6rVwuUW6HjAPkzXVntCtDI8q/niGZbeILc5T/noer+UNDECSy9f8T6ENw7tEKWaHOFcicrqgRv+wXeo2hPiJI2iYsUNs6I8ckd8i4uy/PBEDMW78GlnQLAatk0NC44HKjn8cuIHaETKNG2Vk3rwGBzNgDZ/God1L6JAgMBAAECgYBhCsOwzehBk5pJ2+9pLO+8Rm72EQGvtflb0BBI1zst1x2gBr4DOPedMJe6yymQVrmP/rJItvONdV/DRqHtKMZ2Wa4ul/U1mDnAtS/FkpRYBA5FaXV2hNEW11xBLhL5iGk35P23Bzaa0MJw9Vsd0vjeykridIw/PweDyTdeRBwC2QJBANS+iOaKRuf6BRwCKDmBSHOiZmc/kKnpx2f5BD3h+LWEX3JsNxObMbW1SxQIf2/qwqzIoEm/WbWaOyuwtRZkXQ8CQQCmFjTm5l+Ws2LoQgM+5+eLmPyMyRFOu4G8yqsUkhKuANHK/qrsS1GTbv6SN341NijjNYl05e0h6Jq1T9UZmtrnAkEAwTfzmn7H+3RmI5QJ+IBkzzEWFHv05X0/8DyID7QmcKWzEncaZqIzObdYYu983qa2/LqSaahyz68uQnYRYi7xHQJATr3SgPIRuaH8r360iTtrRHzYp2qgYQJ25On1KECEyKgszp/kqzieSVbjLLFQjavKwMXeEGT+AwiDaJibwJLxWwJAXZApORsqGqdxc9FTxt5iiqG2ZP5DTXxc6E+ihmlmoVl9KncgTf9ez0Q0Qz/4KUTPTHNVgzt1nyBxiLtnyzFavA==
+  # mall_book_public_key mallbook测试环境公钥 不需要替换
+  mall_book_public_key: MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQD0L2DaHOO8ekhktB6RoHxIcki/0v7OUeOn9tX9VBE+jv6PRjqlZRWL3Qezxz5ADtHEyLv+RFFaceXSep6rWyoQ6DRlvLv5CySUAxAM42LLVe4DI3l/0ccEAIuU5NCpwAAj1zkm2X01DwUCZwymLjlqbDlBvQhpq+1fddtTtA/QLQIDAQAB
+  # mall_book_public_key mallbook生产环境公钥  不需要替换
+  # mall_book_public_key: MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCq6OLZKgUHH5wOk9xSBgN7yC17r3PQwMlY9/IorqrOlaIqrU0eAVZ5+dWrJD/3bdu7Ctq8n8trTm/IUYs7wtMg5SKwyX4/N+KQc2N7LL4yCq4vNl41q9sYgrtA0QnZoucIZcq1mwyu7RTDC8Wp7LGddnlkJsmL8masgMxA6cc9NwIDAQAB
+
diff --git a/user/guns-admin/src/main/resources/redis.properties b/user/guns-admin/src/main/resources/redis.properties
index 307358b..8e63a9f 100644
--- a/user/guns-admin/src/main/resources/redis.properties
+++ b/user/guns-admin/src/main/resources/redis.properties
@@ -1,19 +1,19 @@
 #redis���ÿ�ʼ
 # Redis���ݿ�������Ĭ��Ϊ0��
 spring.redis.database=0
-# Redis��������ַ
-spring.redis.host=127.0.0.1
-# Redis���������Ӷ˿�
-spring.redis.port=16379
-# Redis�������������루Ĭ��Ϊ�գ�
-spring.redis.password=cKsEeyffDXG5PzNg8CIbrWxFluXrCprZ
-
 ## Redis��������ַ
 #spring.redis.host=127.0.0.1
-## Redis���������Ӷ˿�
-#spring.redis.port=6379
-## Redis�������������루Ĭ��Ϊ�գ�
-#spring.redis.password=123456
+### Redis���������Ӷ˿�
+#spring.redis.port=16379
+### Redis�������������루Ĭ��Ϊ�գ�
+#spring.redis.password=cKsEeyffDXG5PzNg8CIbrWxFluXrCprZ
+
+## Redis��������ַ
+spring.redis.host=127.0.0.1
+# Redis���������Ӷ˿�
+spring.redis.port=6379
+# Redis�������������루Ĭ��Ϊ�գ�
+spring.redis.password=123456
 
 # ���ӳ������������ʹ�ø�ֵ��ʾû�����ƣ�
 spring.redis.jedis.pool.max-active=1024

--
Gitblit v1.7.1