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