From ca497f8389174bb81e91f840cab70c9579bcdd29 Mon Sep 17 00:00:00 2001
From: 18582019636 <1657978663@qq.com>
Date: 星期二, 25 六月 2024 18:17:01 +0800
Subject: [PATCH] feat: 代码初始化

---
 ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/service/impl/WithdrawServiceImpl.java |  118 +++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 110 insertions(+), 8 deletions(-)

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 93a6cb6..511e740 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
@@ -1,11 +1,14 @@
 package com.ruoyi.user.service.impl;
 
+import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.admin.api.entity.WithdrawalSetting;
 import com.ruoyi.admin.api.feignClient.AdminClient;
 import com.ruoyi.common.core.constant.Constants;
+import com.ruoyi.common.core.constant.WechatConstants;
 import com.ruoyi.common.core.exception.GlobalException;
+import com.ruoyi.common.core.utils.SnowflakeIdWorker;
 import com.ruoyi.user.entity.Order;
 import com.ruoyi.user.entity.RecoveryServe;
 import com.ruoyi.user.entity.User;
@@ -18,27 +21,30 @@
 import com.ruoyi.user.vo.WithdrawListVO;
 import com.ruoyi.user.vo.WithdrawMoneyVO;
 import com.ruoyi.user.vo.WithdrawOrderVO;
+import com.ruoyi.user.vx.HttpUtil;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.io.ClassPathResource;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
 import java.math.BigDecimal;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
 
 /**
- * <p>
  * 用户提现申请记录表 服务实现类
- * </p>
  *
  * @author hjl
  * @since 2024-06-07
  */
 @Service
 public class WithdrawServiceImpl extends ServiceImpl<WithdrawMapper, Withdraw> implements WithdrawService {
+
+    /**
+     * 雪花算法类
+     */
+    private static final SnowflakeIdWorker SNOW_FLAKE_ID_WORKER = new SnowflakeIdWorker(5, 5);
 
     @Resource
     private OrderService orderService;
@@ -48,6 +54,31 @@
     private UserService userService;
     @Resource
     private AdminClient adminClient;
+    /**
+     * 小程序id
+     */
+    @Value("wx.appid")
+    private String appId;
+    /**
+     * 转账名称
+     */
+    @Value("wx.batchName")
+    private String batchName;
+    /**
+     * 商户号
+     */
+    @Value("wx.mchId")
+    private String mchId;
+    /**
+     * 支付证书序列号
+     */
+    @Value("wx.wechatPayserialNo")
+    private String wechatPayserialNo;
+    /**
+     * 转账备注
+     */
+    @Value("wx.transferRemark")
+    private String transferRemark;
 
     @Override
     public WithdrawListVO withdrawList(Integer userid) {
@@ -99,6 +130,7 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public Boolean confirmWithdraw(Integer orderId, Integer userid) {
+        User user = userService.lambdaQuery().eq(User::getId, userid).eq(User::getIsDelete, 0).one();
         Order order = orderService.lambdaQuery().eq(Order::getId, orderId).eq(Order::getIsDelete, 0).one();
         if (null == order) {
             throw new GlobalException("订单信息异常!");
@@ -112,13 +144,21 @@
         } else if (stateList.contains(Constants.ONE)) {
             throw new GlobalException("当前订单已提现通过!");
         }
-        User user = userService.lambdaQuery().eq(User::getId, userid).eq(User::getIsDelete, 0).one();
         // 系统审核设置
         WithdrawalSetting setting = adminClient.withdrawProcess().getData();
         Withdraw withdraw = new Withdraw();
+        // 未开启全局 提现审核,则用户提现不需要后台审核
         if (Constants.ZERO.equals(setting.getEnableProcess())) {
+            // 已通过
+            withdraw.setState(Constants.ONE);
+            // 商家微信打款至微信零钱
+            boolean update = weChatPay(order.getOrderMoney(), user.getOpenId());
+            if (!update) {
+                throw new GlobalException("交易提现失败,请检查是否绑定微信!");
+            }
+        } else {
+            // 待审核
             withdraw.setState(Constants.ZERO);
-            // todo 商家微信打款至微信零钱
         }
         withdraw.setUserId(user.getId());
         withdraw.setUserPhone(user.getPhone());
@@ -127,4 +167,66 @@
         withdraw.setOrderId(orderId);
         return this.save(withdraw);
     }
+
+    private boolean weChatPay(BigDecimal orderMoney, String openId) {
+        Map<String, Object> postMap = new HashMap<>(8);
+        // 小程序 id
+        postMap.put(WechatConstants.APP_ID, appId);
+        postMap.put(WechatConstants.OUT_BATCH_NO, String.valueOf(UUID.randomUUID()).replaceAll("-", ""));
+        // 该笔批量转账的名称
+        postMap.put(WechatConstants.BATCH_NAME, batchName);
+        // 转账说明,UTF8编码,最多允许32个字符
+        postMap.put(WechatConstants.BATCH_REMARK, batchName);
+        // 转账金额单位为“分”。 总金额
+        postMap.put(WechatConstants.TOTAL_AMOUNT, orderMoney.multiply(new BigDecimal(Constants.ONE_HUNDRED)));
+        // 转账总笔数
+        postMap.put(WechatConstants.TOTAL_NUM, Constants.ONE);
+        List<Map<String, Object>> list = new ArrayList<>();
+        Map<String, Object> subMap = new HashMap<>(4);
+        // 商家明细单号 该商家下唯一
+        // subMap.put("out_detail_no", RandomUtil.randomString(32))
+        subMap.put(WechatConstants.OUT_DETAIL_NO, SNOW_FLAKE_ID_WORKER.nextId());
+        // 转账金额
+        subMap.put(WechatConstants.TRANSFER_AMOUNT, orderMoney);
+        // 转账备注
+        subMap.put(WechatConstants.TRANSFER_REMARK, transferRemark);
+        // 用户在直连商户应用下的用户标示
+        subMap.put(WechatConstants.OPEN_ID, openId);
+        // 大金额需要传入真实姓名
+        /*subMap.put("user_name",
+        RsaCryptoUtil.encryptOAEP(userName,WechatPayV3Util.getSaveCertificates(privatekeypath)))*/
+        list.add(subMap);
+        postMap.put(WechatConstants.TRANSFER_DETAIL_LIST, list);
+        // 使用类加载器获取资源 URL
+        ClassPathResource classPathResource = new ClassPathResource("vx/apiclient_key.pem");
+        /*// 获取 resources 目录下的文件路径,假设文件路径为 "resources/data/example.txt"
+        String filePath = "resources/data/vx/apiclient_key.pem";
+        File file = new File(filePath);
+        // 输出文件的绝对路径
+        String absolutePath = file.getAbsolutePath();*/
+        String result = HttpUtil.postTransBatRequest(
+                WechatConstants.WE_CHAT_URL_PRE,
+                JSONObject.toJSONString(postMap),
+                // 支付证书序列号
+                wechatPayserialNo,
+                // 商户号
+                mchId,
+                classPathResource.getPath(), WechatConstants.WE_CHAT_URL_SUF);
+        JSONObject jsonObject = JSONObject.parseObject(result);
+        /*
+         * 成功示例
+         * {
+         *   "out_batch_no": "plfk2020042013",
+         *   "batch_id": "1030000071100999991182020050700019480001",
+         *   "create_time": "2015-05-20T13:29:35.120+08:00"
+         * }
+         */
+        if (null == jsonObject || null != jsonObject.get(WechatConstants.CREATE_TIME)) {
+            //转账成功
+            return Boolean.TRUE;
+        } else {
+            return Boolean.FALSE;
+        }
+    }
+
 }

--
Gitblit v1.7.1