From e306c0512dd3650f1882166da177800868265b27 Mon Sep 17 00:00:00 2001
From: liuhaonan <konodioda2333@vip.qq.com>
Date: 星期四, 24 三月 2022 18:01:14 +0800
Subject: [PATCH] 费率相关更改

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java |   73 +++++++++++++++++++++++++++---------
 1 files changed, 55 insertions(+), 18 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java
index eedfb8c..5d8bc00 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java
@@ -1,7 +1,7 @@
 package com.sandu.ximon.admin.pay.wx;
 
+import cn.dreampie.encription.EncriptionKit;
 import cn.hutool.core.codec.Base64;
-import cn.hutool.crypto.SecureUtil;
 import com.github.binarywang.wxpay.bean.notify.WxPayOrderNotifyResult;
 import com.github.binarywang.wxpay.bean.notify.WxPayRefundNotifyResult;
 import com.github.binarywang.wxpay.bean.request.WxPayRefundRequest;
@@ -35,45 +35,58 @@
     private final com.github.binarywang.wxpay.service.WxPayService wxPayService;
     //private final WxPayProperties wxPayProperties;
     public static final String WECHAT_ORDER_PAY_CALLBACK_URL = "http://49.235.239.118:20012/callback/pay/wechatCallback";
+    private final UsrWxPayConfigService wxPayConfigService;
 
     /**
      * app鏀粯
      *
-     * @param openId
      * @param body     鍟嗗搧鎻忚堪
      * @param orderId  璁㈠崟id
      * @param totalFee 鏀粯閲戦锛堝垎锛�
      * @return
      */
-    public SortedMap<Object, Object> miniAppPay(WxPayService wxPayService, String openId, String body,
-                                                String orderId, int totalFee, String callbackUrl) {
+    public SortedMap<Object, Object> appPay(String body, String orderSn, int totalFee,Long poleId) {
+        WxConfigEntity wxConfig = wxPayConfigService.getConfigByPoleId(poleId);
         WxPayUnifiedOrderRequest wxPayUnifiedOrderRequest = new WxPayUnifiedOrderRequest();
         wxPayUnifiedOrderRequest.setBody(body);
-        wxPayUnifiedOrderRequest.setOutTradeNo(orderId);
+        wxPayUnifiedOrderRequest.setOutTradeNo(orderSn);
         wxPayUnifiedOrderRequest.setTotalFee(totalFee);
-        wxPayUnifiedOrderRequest.setOpenid(openId);
 
-        wxPayUnifiedOrderRequest.setSignType(WxPayConstants.SignType.MD5);
+        //wxPayUnifiedOrderRequest.setSignType(WxPayConstants.SignType.MD5);
         wxPayUnifiedOrderRequest.setSpbillCreateIp(IpUtil.getRealIp());
-        wxPayUnifiedOrderRequest.setNotifyUrl(callbackUrl);
-        wxPayUnifiedOrderRequest.setTradeType(WxPayConstants.TradeType.JSAPI);
+        wxPayUnifiedOrderRequest.setNotifyUrl(WECHAT_ORDER_PAY_CALLBACK_URL);
+        wxPayUnifiedOrderRequest.setTradeType(WxPayConstants.TradeType.APP);
 
         try {
             WxPayUnifiedOrderResult wxPayUnifiedOrderResult = wxPayService.unifiedOrder(wxPayUnifiedOrderRequest);
             String time = String.valueOf(System.currentTimeMillis() / 1000);
             if (WxPayConstants.ResultCode.SUCCESS.equals(wxPayUnifiedOrderResult.getResultCode())) {
-                SortedMap<Object, Object> hashMap = new TreeMap<>();
-                hashMap.put("appId", wxPayUnifiedOrderResult.getAppid());
+                SortedMap<Object, Object> parameters = new TreeMap<>();
+                /*hashMap.put("appId", wxPayUnifiedOrderResult.getAppid());
                 hashMap.put("nonceStr", wxPayUnifiedOrderResult.getNonceStr());
-                hashMap.put("package", "prepay_id=" + wxPayUnifiedOrderResult.getPrepayId());
+                hashMap.put("prepayId", wxPayUnifiedOrderResult.getPrepayId());
+                //  hashMap.put("package", "prepay_id=" + wxPayUnifiedOrderResult.getPrepayId());
                 hashMap.put("signType", WxPayConstants.SignType.MD5);
                 hashMap.put("timeStamp", time);
-                String wechatSign = createSign(wxPayService.getConfig().getMchKey(), hashMap);
-                hashMap.put("paySign", wechatSign);
-                return hashMap;
+                hashMap.put("partnerid", wxPayProperties.getMchId());*/
+                parameters.put("appid", wxPayUnifiedOrderResult.getAppid());
+
+                parameters.put("noncestr", wxPayUnifiedOrderResult.getNonceStr()); // 闅忔満瀛楃涓�
+                parameters.put("partnerid", wxConfig.getMchId()); // 鍟嗘埛id
+
+                //  parameters.put("out_trade_no", orderId);//鍟嗘埛璁㈠崟鍙�
+                parameters.put("prepayid", wxPayUnifiedOrderResult.getPrepayId());
+                parameters.put("package", "Sign=WXPay");
+                parameters.put("timestamp", time);
+
+                String sign = createSign(parameters, wxConfig.getPrivateKey());
+
+                //hashMap.put("paySign", wechatSign);
+                parameters.put("Sign", sign);
+                return parameters;
             } else {
                 log.error("寰俊鏀粯澶辫触锛寋}", wxPayUnifiedOrderResult.getErrCodeDes());
-                throw new BusinessException("寰俊鏀粯澶辫触锛�" + wxPayUnifiedOrderResult);
+                throw new BusinessException("寰俊鏀粯澶辫触锛�" + wxPayUnifiedOrderResult.getErrCodeDes());
             }
         } catch (WxPayException e) {
             log.error("寰俊鏀粯澶辫触锛寋}", e.getErrCodeDes());
@@ -81,7 +94,7 @@
         }
     }
 
-    private String createSign(String mchKey, SortedMap<Object, Object> parameters) {
+/*    private String createSign(SortedMap<Object, Object> parameters) {
         StringBuffer sb = new StringBuffer();
         Set es = parameters.entrySet();// 鎵�鏈夊弬涓庝紶鍙傜殑鍙傛暟鎸夌収accsii鎺掑簭锛堝崌搴忥級
         for (Object e : es) {
@@ -92,9 +105,32 @@
                 sb.append(k + "=" + v + "&");
             }
         }
-        sb.append("key=" + mchKey);
+        sb.append("key=" + wxPayProperties.getMchKey());
         System.out.println("瀛楃涓叉嫾鎺ュ悗鏄�:" + sb.toString());
         return SecureUtil.md5(sb.toString()).toUpperCase();
+    }*/
+
+    /**
+     * @param parameters
+     * @return
+     */
+    @SuppressWarnings("rawtypes")
+    private String createSign(SortedMap<Object, Object> parameters, String Key) {
+        StringBuffer sb = new StringBuffer();
+        Set es = parameters.entrySet();// 鎵�鏈夊弬涓庝紶鍙傜殑鍙傛暟鎸夌収accsii鎺掑簭锛堝崌搴忥級
+        Iterator it = es.iterator();
+        while (it.hasNext()) {
+            Map.Entry entry = (Map.Entry) it.next();
+            String k = (String) entry.getKey();
+            Object v = entry.getValue();
+            if (null != v && !"".equals(v) && !"sign".equals(k) && !"key".equals(k)) {
+                sb.append(k + "=" + v + "&");
+            }
+        }
+        sb.append("key=" + Key);
+        System.out.println("瀛楃涓叉嫾鎺ュ悗鏄�:" + sb.toString());
+        String sign = EncriptionKit.encrypt(sb.toString()).toUpperCase();
+        return sign;
     }
 
     public WxPayOrderNotifyResult parseOrderNotifyResult(WxPayService wxPayService, String xmlData) {
@@ -180,6 +216,7 @@
 
     /**
      * 閫�娆�
+     *
      * @param totalAmount
      * @param refundAmount
      * @param outTradeNo

--
Gitblit v1.9.3