From 7e92d9c7f76777c48f76376c99ffaae2e16fe7ed Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期二, 01 七月 2025 14:37:08 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev --- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java | 210 +++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 148 insertions(+), 62 deletions(-) diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java index 7730e29..9001b02 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java @@ -14,16 +14,10 @@ import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.core.vo.UserDto; import com.ruoyi.common.redis.service.RedisService; -import com.ruoyi.order.entity.Order; -import com.ruoyi.order.entity.Withdraw; -import com.ruoyi.order.entity.WithdrawDetail; -import com.ruoyi.order.entity.WithdrawalSetting; +import com.ruoyi.order.entity.*; import com.ruoyi.order.mapper.WithdrawMapper; import com.ruoyi.order.request.WithdrawExportRequest; -import com.ruoyi.order.service.OrderService; -import com.ruoyi.order.service.WithdrawDetailService; -import com.ruoyi.order.service.WithdrawService; -import com.ruoyi.order.service.WithdrawalSettingService; +import com.ruoyi.order.service.*; import com.ruoyi.order.vo.MoneyQueryRequest; import com.ruoyi.order.vo.UserWithdrawRecordVO; import com.ruoyi.order.vx.HttpUtil; @@ -56,6 +50,8 @@ @Resource private WithdrawalSettingService withdrawalSettingService; + @Resource + private WithdrawRecordService withdrawRecordService; @Resource private OrderService orderService; @Resource @@ -138,7 +134,7 @@ throw new GlobalException("当前订单提现申请已通过!"); } - return weChatPay(order.getOrderMoney(), openId,list.get(0).getId()); + return weChatPay(order.getSubsidy()!=null?order.getSubsidy().add(order.getOrderMoney()):order.getOrderMoney(), openId,list.get(0).getId(),order.getServeName()); } @Override @@ -245,17 +241,25 @@ withdraw.setApplyForMoney(order.getOrderMoney()); withdraw.setOrderId(orderId); withdraw.setCityCode(order.getCityCode()); - this.save(withdraw); + WithdrawRecord withdrawRecord = new WithdrawRecord(); + withdrawRecord.setWithdrawId(withdraw.getId()); + withdrawRecord.setOrderId(withdraw.getOrderId()); + withdrawRecord.setUserId(withdraw.getUserId()); + withdrawRecord.setWithdrawType(1); + withdrawRecord.setCreateTime(new Date()); + withdrawRecord.setAuditStatus(1); + withdrawRecordService.save(withdrawRecord); + // 未开启全局 提现审核,则用户提现不需要后台审核 if (Constants.ZERO.equals(withdrawalSetting.getEnableProcess())) { // 已通过 withdraw.setState(Constants.ONE); // 商家微信打款至微信零钱 - boolean update = weChatPay(order.getOrderMoney(), openId,withdraw.getId()); -// if (!update) { -// throw new GlobalException("交易提现失败,请检查是否绑定微信!"); -// } + boolean update = weChatPay(order.getOrderMoney(), openId,withdraw.getId(),order.getServerName()); + if (!update) { + throw new GlobalException("交易提现失败,请检查是否绑定微信!"); + } } else { // 待审核 withdraw.setState(Constants.ZERO); @@ -272,15 +276,94 @@ @Resource private WithdrawDetailService withdrawDetailService; - private boolean weChatPay(BigDecimal orderMoney, String openId,String withdrawId) { +// private boolean weChatPay(BigDecimal orderMoney, String openId,String withdrawId) { +// if (StringUtils.isBlank(openId)) { +// return false; +// } +// +// BigDecimal maxTransferAmount = new BigDecimal("20000"); // 单次转账限额,单位为分 +// int totalTransfers = orderMoney.multiply(new BigDecimal("100")).divide(maxTransferAmount, 0, RoundingMode.UP).intValue(); +// boolean allTransfersSuccessful = true; +// +// for (int i = 0; i < totalTransfers; i++) { +// BigDecimal transferAmount; +// if (i < totalTransfers - 1) { +// transferAmount = maxTransferAmount; +// } else { +// // 最后一笔转账,金额为剩余金额 +// transferAmount = orderMoney.multiply(new BigDecimal("100")).subtract(maxTransferAmount.multiply(new BigDecimal(i))).setScale(0, RoundingMode.DOWN); +// } +// +// Map<String, Object> postMap = new HashMap<>(8); +// postMap.put(WechatConstants.APP_ID, "wx98563d0ec9cf21c8"); +// postMap.put(WechatConstants.OUT_BATCH_NO, String.valueOf(UUID.randomUUID()).replaceAll("-", "")); +// System.err.println("====="+postMap.get(WechatConstants.OUT_BATCH_NO)); +// postMap.put(WechatConstants.BATCH_NAME, "二手回收提现"); +// postMap.put(WechatConstants.BATCH_REMARK, "二手回收提现"); +// postMap.put(WechatConstants.TOTAL_AMOUNT, transferAmount); +// postMap.put(WechatConstants.TOTAL_NUM, Constants.ONE); +// +// List<Map<String, Object>> list = new ArrayList<>(); +// Map<String, Object> subMap = new HashMap<>(4); +// subMap.put(WechatConstants.OUT_DETAIL_NO, String.valueOf(SNOW_FLAKE_ID_WORKER.nextId())); +// subMap.put(WechatConstants.TRANSFER_AMOUNT, transferAmount); +// subMap.put(WechatConstants.TRANSFER_REMARK, "二手回收提现到账"); +// subMap.put(WechatConstants.OPEN_ID, openId); +// list.add(subMap); +// postMap.put(WechatConstants.TRANSFER_DETAIL_LIST, list); +// +// // 使用类加载器获取资源 URL +//// String path = ClassLoader.getSystemResource("/usr/local/vx/apiclient_key.pem").getPath(); +// +//// String result = HttpUtil.postTransBatRequest( +//// WechatConstants.WE_CHAT_URL_PRE, +//// JSONObject.toJSONString(postMap), +//// "7EEA04429B006E12AAA421C002EC48BBEED5BE94", +//// "1665330417", +//// "/usr/local/vx/apiclient_key.pem", WechatConstants.WE_CHAT_URL_SUF); +// String result = HttpUtil.postTransBatRequest( +// WechatConstants.WE_CHAT_URL_PRE, +// JSONObject.toJSONString(postMap), +// "7EEA04429B006E12AAA421C002EC48BBEED5BE94", +// "1665330417", +// "D:\\study\\JiaDianHuiShou\\ruoyi-service\\ruoyi-order\\src\\main\\java\\com\\ruoyi\\order\\vx\\apiclient_key.pem", WechatConstants.WE_CHAT_URL_SUF); +// +// JSONObject jsonObject = JSONObject.parseObject(result); +// +// WithdrawDetail withdrawDetail = new WithdrawDetail(); +// withdrawDetail.setWithdrawId(withdrawId); +// withdrawDetail.setMoney(transferAmount); +// withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); +// withdrawDetailService.save(withdrawDetail); +// +// if (jsonObject.containsKey(WechatConstants.CREATE_TIME)) { +// // 转账成功 +// //保存转账明细 +//// WithdrawDetail withdrawDetail = new WithdrawDetail(); +//// withdrawDetail.setWithdrawId(withdrawId); +//// withdrawDetail.setMoney(transferAmount); +//// withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); +//// withdrawDetailService.save(withdrawDetail); +// +// +// } else { +// allTransfersSuccessful = false; +// break; +// } +// +// } +// +// return allTransfersSuccessful; +// } + + // 上架打款到用户零钱接口已弃用 用新版商家转账接口 + private boolean weChatPay(BigDecimal orderMoney, String openId,String withdrawId,String serverName) { if (StringUtils.isBlank(openId)) { return false; } - - BigDecimal maxTransferAmount = new BigDecimal("20000"); // 单次转账限额,单位为分 + BigDecimal maxTransferAmount = new BigDecimal("200000"); // 单次转账限额,单位为分 int totalTransfers = orderMoney.multiply(new BigDecimal("100")).divide(maxTransferAmount, 0, RoundingMode.UP).intValue(); boolean allTransfersSuccessful = true; - for (int i = 0; i < totalTransfers; i++) { BigDecimal transferAmount; if (i < totalTransfers - 1) { @@ -292,63 +375,66 @@ Map<String, Object> postMap = new HashMap<>(8); postMap.put(WechatConstants.APP_ID, "wx98563d0ec9cf21c8"); - postMap.put(WechatConstants.OUT_BATCH_NO, String.valueOf(UUID.randomUUID()).replaceAll("-", "")); - System.err.println("====="+postMap.get(WechatConstants.OUT_BATCH_NO)); - postMap.put(WechatConstants.BATCH_NAME, "二手回收提现"); - postMap.put(WechatConstants.BATCH_REMARK, "二手回收提现"); - postMap.put(WechatConstants.TOTAL_AMOUNT, transferAmount); - postMap.put(WechatConstants.TOTAL_NUM, Constants.ONE); - + // 订单号 + postMap.put("out_bill_no", String.valueOf(UUID.randomUUID()).replaceAll("-", "")); + System.err.println("====="+postMap.get("out_bill_no")); + postMap.put(WechatConstants.OPEN_ID, openId); + // 转账金额 + postMap.put("transfer_amount", transferAmount); + postMap.put("transfer_scene_id", "1010"); + // 转账备注 + postMap.put("transfer_remark", "二手回收提现确认收款"); + // 回调地址 + postMap.put("notify_url", "https://hyhsbqgc.com/api/ruoyi-order/wx/wxChatPay"); + // 转账场景报备信息 List<Map<String, Object>> list = new ArrayList<>(); - Map<String, Object> subMap = new HashMap<>(4); - subMap.put(WechatConstants.OUT_DETAIL_NO, String.valueOf(SNOW_FLAKE_ID_WORKER.nextId())); - subMap.put(WechatConstants.TRANSFER_AMOUNT, transferAmount); - subMap.put(WechatConstants.TRANSFER_REMARK, "二手回收提现到账"); - subMap.put(WechatConstants.OPEN_ID, openId); - list.add(subMap); - postMap.put(WechatConstants.TRANSFER_DETAIL_LIST, list); - - // 使用类加载器获取资源 URL -// String path = ClassLoader.getSystemResource("/usr/local/vx/apiclient_key.pem").getPath(); - -// String result = HttpUtil.postTransBatRequest( -// WechatConstants.WE_CHAT_URL_PRE, -// JSONObject.toJSONString(postMap), -// "7EEA04429B006E12AAA421C002EC48BBEED5BE94", -// "1665330417", -// "/usr/local/vx/apiclient_key.pem", WechatConstants.WE_CHAT_URL_SUF); + Map<String, Object> info = new HashMap<>(); + info.put("info_type","回收商品名称"); + info.put("info_content",serverName); + list.add(info); + postMap.put("transfer_scene_report_infos", list); String result = HttpUtil.postTransBatRequest( - WechatConstants.WE_CHAT_URL_PRE, + WechatConstants.WE_CHAT_PAY_URL_PRE, JSONObject.toJSONString(postMap), "7EEA04429B006E12AAA421C002EC48BBEED5BE94", "1665330417", - "D:\\study\\JiaDianHuiShou\\ruoyi-service\\ruoyi-order\\src\\main\\java\\com\\ruoyi\\order\\vx\\apiclient_key.pem", WechatConstants.WE_CHAT_URL_SUF); + "D:\\apiclient_key.pem", +// "/usr/local/vx/apiclient_key.pem", + "/v3/fund-app/mch-transfer/transfer-bills"); JSONObject jsonObject = JSONObject.parseObject(result); - - WithdrawDetail withdrawDetail = new WithdrawDetail(); - withdrawDetail.setWithdrawId(withdrawId); - withdrawDetail.setMoney(transferAmount); - withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); - withdrawDetailService.save(withdrawDetail); - +// WithdrawDetail withdrawDetail = new WithdrawDetail(); +// withdrawDetail.setWithdrawId(withdrawId); +// withdrawDetail.setMoney(transferAmount); +// withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); +// withdrawDetailService.save(withdrawDetail); + System.err.println(jsonObject); +// WithdrawDetail withdrawDetail = new WithdrawDetail(); +// withdrawDetail.setWithdrawId(withdrawId); +// withdrawDetail.setMoney(transferAmount); +// withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); +// withdrawDetailService.save(withdrawDetail); if (jsonObject.containsKey(WechatConstants.CREATE_TIME)) { + String string = jsonObject.getString("package_info"); + Withdraw withdraw = this.getById(withdrawId); + + Order order = orderService.getById(withdraw.getOrderId()); + order.setIsWithdrawal(2); + order.setPackageInfo(string); + orderService.updateById(order); // 转账成功 //保存转账明细 -// WithdrawDetail withdrawDetail = new WithdrawDetail(); -// withdrawDetail.setWithdrawId(withdrawId); -// withdrawDetail.setMoney(transferAmount); -// withdrawDetail.setOutBatchNo((String) postMap.get(WechatConstants.OUT_BATCH_NO)); -// withdrawDetailService.save(withdrawDetail); - - + WithdrawDetail withdrawDetail = new WithdrawDetail(); + withdrawDetail.setWithdrawId(withdrawId); + withdrawDetail.setMoney(transferAmount); + withdrawDetail.setOutBatchNo(postMap.get("out_bill_no")+""); + withdrawDetailService.save(withdrawDetail); } else { - allTransfersSuccessful = false; - break; + throw new GlobalException("提现失败,失败原因:"+jsonObject.getString("message")); +// allTransfersSuccessful = false; +// break; } - } - return allTransfersSuccessful; } -- Gitblit v1.7.1