From 4e30491ff75e23e4cce21713a79c03421addd3f5 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期三, 09 四月 2025 09:39:00 +0800 Subject: [PATCH] 提现代码 --- ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java | 1 ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/entity/Order.java | 3 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/entity/Order.java | 4 ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/vo/WithdrawOrderVO.java | 2 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/WxChatPayCallBack.java | 199 +++++++++++++++++++++++++++++++++++++++++++++++++ ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/WithdrawServiceImpl.java | 19 +++- ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/vo/UserDto.java | 1 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vx/TestWxPay.java | 2 8 files changed, 222 insertions(+), 9 deletions(-) diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/entity/Order.java b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/entity/Order.java index f34f85f..16a2b7e 100644 --- a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/entity/Order.java +++ b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/api/entity/Order.java @@ -194,5 +194,6 @@ @ApiModelProperty("回收单凭证(多张照片 ','隔开)") @TableField("paper_pic") private String paperPic; - + @ApiModelProperty("拉起确认收款页面参数") + private String packageInfo; } diff --git a/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/vo/UserDto.java b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/vo/UserDto.java index 9fb8c2c..5ee6696 100644 --- a/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/vo/UserDto.java +++ b/ruoyi-common/ruoyi-common-core/src/main/java/com/ruoyi/common/core/vo/UserDto.java @@ -12,4 +12,5 @@ private String profilePicture; private String phone; private String userNo; + private String openId; } diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/WxChatPayCallBack.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/WxChatPayCallBack.java new file mode 100644 index 0000000..799dfd0 --- /dev/null +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/WxChatPayCallBack.java @@ -0,0 +1,199 @@ +package com.ruoyi.order.controller; + + +import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.ruoyi.common.core.constant.Constants; +import com.ruoyi.common.core.constant.WechatConstants; +import com.ruoyi.common.core.domain.BaseEntity; +import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.exception.GlobalException; +import com.ruoyi.common.core.utils.StringUtils; +import com.ruoyi.common.core.vo.UserDto; +import com.ruoyi.common.security.annotation.RequiresPermissions; +import com.ruoyi.order.entity.ChangeDispatch; +import com.ruoyi.order.entity.Order; +import com.ruoyi.order.entity.Withdraw; +import com.ruoyi.order.entity.WithdrawDetail; +import com.ruoyi.order.request.ChangeDispatchRequest; +import com.ruoyi.order.service.ChangeDispatchService; +import com.ruoyi.order.service.OrderService; +import com.ruoyi.order.service.WithdrawDetailService; +import com.ruoyi.order.service.WithdrawService; +import com.ruoyi.order.vx.HttpUtil; +import com.ruoyi.system.api.RemoteUserService; +import com.ruoyi.user.api.feignClient.UserClient; +import com.wechat.pay.contrib.apache.httpclient.util.AesUtil; +import com.wechat.pay.java.core.Config; +import com.wechat.pay.java.core.RSAAutoCertificateConfig; +import com.wechat.pay.java.core.notification.NotificationConfig; +import com.wechat.pay.java.core.notification.NotificationParser; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiImplicitParam; +import io.swagger.annotations.ApiImplicitParams; +import io.swagger.annotations.ApiOperation; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.http.ResponseEntity; +import org.springframework.web.bind.annotation.*; + +import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.BufferedReader; +import java.math.BigDecimal; +import java.math.RoundingMode; +import java.nio.charset.StandardCharsets; +import java.time.LocalDateTime; +import java.util.*; +import java.util.stream.Collectors; + +/** + * <p> + * 商家转账回调 + * </p> + * + * @author hjl + * @since 2024-05-31 + */ +@RestController +@RequestMapping("/wx") +public class WxChatPayCallBack { + + @Autowired + private WithdrawDetailService withdrawDetailService; + @Resource + private OrderService orderService; + @Autowired + private WithdrawService withdrawService; + @Autowired + private UserClient userClient; + /** + * 微信商户零线转账 - 回调通知 + * @Context注解 把HTTP请求上下文对象注入进来,HttpServletRequest、HttpServletResponse、UriInfo 等 + * @return + */ + @PostMapping("/wxChatPay") + public String wxPayCallback(HttpServletRequest request) { + Map<String, String> map = new HashMap<>(); + Map<String,String> errMap = new HashMap<>(); + try { System.err.println("请求"+request); + BufferedReader reader = request.getReader(); + String string1 = reader.toString(); + System.err.println("请求reader"+string1); + StringBuilder requestBody = new StringBuilder(); + String line; + while ((line = reader.readLine()) != null) { + requestBody.append(line); + } + System.err.println("全部请求体"+requestBody); + JSONObject jsonObject = JSONObject.parseObject(requestBody.toString()); + JSONObject resource = jsonObject.getJSONObject("resource"); + + AesUtil aesUtil = new AesUtil("TA2npSNWmS0GcB0tFFRWA94rm1M0iSFs".getBytes(StandardCharsets.UTF_8)); + String decryptedData = aesUtil.decryptToString(resource.getString("associated_data").getBytes(StandardCharsets.UTF_8), resource.getString("nonce").getBytes(StandardCharsets.UTF_8), + resource.getString("ciphertext")); + System.err.println("微信解密的字符串信息"+decryptedData); + JSONObject jsonInfo = (JSONObject) JSONObject.parse(decryptedData); + String transferBillNo = jsonInfo.getString("transfer_bill_no"); + String state = jsonInfo.getString("state"); + WithdrawDetail withdrawDetail = withdrawDetailService.lambdaQuery().eq(WithdrawDetail::getOutBatchNo, transferBillNo).one(); + Withdraw withdraw = withdrawService.getById(withdrawDetail.getWithdrawId()); + Order order = orderService.getById(withdraw.getOrderId()); + UserDto data = userClient.getUser(order.getUserId()).getData(); + if ("SUCCESS".equals(state)){ + order.setIsWithdrawal(1); + withdrawDetail.setStatus("SUCCESS"); + withdrawDetailService.updateById(withdrawDetail); + orderService.updateById(order); + }else if ("CANCELLED".equals(state)){ + // 校验提现 + List<Withdraw> list = withdrawService.lambdaQuery().eq(Withdraw::getUserId, order.getUserId()) + .eq(Withdraw::getOrderId, order.getId()).list(); + List<Integer> stateList = list.stream().map(Withdraw::getState).collect(Collectors.toList()); + if (stateList.contains(Constants.ONE)) { + throw new GlobalException("当前订单提现申请已通过!"); + } + // 超时未收款 撤销 重新发起转账 更新packageInfo + weChatPay(order.getOrderMoney(), data.getOpenId(),list.get(0).getId(),order.getServeName()); + } + map.put("code", "SUCCESS"); + map.put("message", "成功"); + } catch (Exception e) { + errMap.put("code", "FAIL"); + errMap.put("message", "服务器内部错误"); + } + return JSON.toJSONString(map); + + } + private boolean weChatPay(BigDecimal orderMoney, String openId, String withdrawId, String serverName) { + if (StringUtils.isBlank(openId)) { + return false; + } + 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) { + 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"); + // 订单号 + String s = String.valueOf(UUID.randomUUID()).replaceAll("-", ""); + postMap.put("out_bill_no", s); + System.err.println("====="+postMap.get(WechatConstants.OUT_BATCH_NO)); + postMap.put(WechatConstants.OPEN_ID, openId); + // 转账金额 + postMap.put("transfer_amount", transferAmount); + // 转账备注 + postMap.put("transfer_remark", transferAmount); + // 回调地址 + postMap.put("notify_url", transferAmount); + // 转账场景报备信息 + Map<String, Object> info = new HashMap<>(); + info.put("info_type","回收商品名称"); + info.put("info_content",serverName); + postMap.put("transfer_scene_report_infos", com.alibaba.fastjson2.JSONObject.toJSONString(info)); + String result = HttpUtil.postTransBatRequest( + WechatConstants.WE_CHAT_PAY_URL_PRE, + com.alibaba.fastjson2.JSONObject.toJSONString(postMap), + "7EEA04429B006E12AAA421C002EC48BBEED5BE94", + "1665330417", + "E:\\ershoucert\\apiclient_key.pem", WechatConstants.WE_CHAT_URL_SUF); + com.alibaba.fastjson2.JSONObject jsonObject = com.alibaba.fastjson2.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)) { + String string = jsonObject.getString("package_info"); + Withdraw withdraw = withdrawService.getById(withdrawId); + WithdrawDetail one = withdrawDetailService.lambdaQuery().eq(WithdrawDetail::getWithdrawId, withdrawId).last("limit 1").one(); + if (one!=null){ + one.setOutBatchNo(s); + one.setStatus("FAIL"); + withdrawDetailService.updateById(one); + Order order = orderService.getById(withdraw.getOrderId()); + order.setPackageInfo(string); + order.setIsWithdrawal(0); + orderService.updateById(order); + } + } else { + allTransfersSuccessful = false; + break; + } + + } + + return allTransfersSuccessful; + } + +} diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/entity/Order.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/entity/Order.java index 6f5d07f..5c1c32e 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/entity/Order.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/entity/Order.java @@ -61,7 +61,9 @@ @ApiModelProperty("站点名称") @TableField("site_name") private String siteName; - + @ApiModelProperty("拉起确认收款页面参数") + @TableField("package_info") + private String packageInfo; @ApiModelProperty("回收服务id") @TableField("serve_id") private Integer serveId; 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 5e929ad..098722f 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 @@ -372,7 +372,8 @@ Map<String, Object> postMap = new HashMap<>(8); postMap.put(WechatConstants.APP_ID, "wx98563d0ec9cf21c8"); // 订单号 - postMap.put("out_bill_no", String.valueOf(UUID.randomUUID()).replaceAll("-", "")); + String s = String.valueOf(UUID.randomUUID()).replaceAll("-", ""); + postMap.put("out_bill_no", s); System.err.println("====="+postMap.get(WechatConstants.OUT_BATCH_NO)); postMap.put(WechatConstants.OPEN_ID, openId); // 转账金额 @@ -399,13 +400,19 @@ // 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.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(s); + withdrawDetailService.save(withdrawDetail); } else { diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vx/TestWxPay.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vx/TestWxPay.java index 6205fd5..4333da3 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vx/TestWxPay.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vx/TestWxPay.java @@ -40,7 +40,7 @@ // 转账备注 postMap.put("transfer_remark", "二手回收提现确认收款"); // 回调地址 -// postMap.put("notify_url", transferAmount); + postMap.put("notify_url", "https://y6cgd7wo3ooa.guyubao.com/order/wx/wxChatPay"); // 转账场景报备信息 List<Map<String, Object>> list = new ArrayList<>(); Map<String, Object> info = new HashMap<>(); diff --git a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java index 8aacf0b..5e28ae5 100644 --- a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java +++ b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java @@ -82,6 +82,7 @@ withdrawOrder.setCompleteTime(order.getCreateTime()); withdrawOrder.setIsWithdrawal(order.getIsWithdrawal()); withdrawOrder.setMoney(order.getOrderMoney()); + withdrawOrder.setPackageInfo(order.getPackageInfo()); if (order.getAddress()!=null) { withdrawOrder.setAddress(order.getReservationAddress() + order.getAddress()); }else { diff --git a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/vo/WithdrawOrderVO.java b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/vo/WithdrawOrderVO.java index 57b6517..ad44d1c 100644 --- a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/vo/WithdrawOrderVO.java +++ b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/vo/WithdrawOrderVO.java @@ -44,5 +44,7 @@ @ApiModelProperty("订单金额") private BigDecimal money; + @ApiModelProperty("拉起确认收款页面参数") + private String packageInfo; } -- Gitblit v1.7.1