From 923c9cec3403ae2abcc523ea73918f243977e546 Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期二, 23 八月 2022 11:28:56 +0800
Subject: [PATCH] changes

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java |   97 +++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 75 insertions(+), 22 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 e0d9746..8097189 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,10 @@
 package com.sandu.ximon.admin.pay.wx;
 
-import cn.dreampie.encription.EncriptionKit;
-import cn.hutool.core.codec.Base64;
+import cn.binarywang.wx.miniapp.api.WxMaService;
+import cn.binarywang.wx.miniapp.api.impl.WxMaServiceImpl;
+import cn.binarywang.wx.miniapp.bean.WxMaJscode2SessionResult;
+import cn.binarywang.wx.miniapp.config.impl.WxMaDefaultConfigImpl;
+import cn.hutool.crypto.SecureUtil;
 import cn.hutool.http.HttpUtil;
 import com.alibaba.fastjson.JSON;
 import com.github.binarywang.wxpay.bean.notify.WxPayOrderNotifyResult;
@@ -13,6 +16,7 @@
 import com.github.binarywang.wxpay.config.WxPayConfig;
 import com.github.binarywang.wxpay.constant.WxPayConstants;
 import com.github.binarywang.wxpay.exception.WxPayException;
+import com.github.binarywang.wxpay.service.WxPayService;
 import com.sandu.common.execption.BusinessException;
 import com.sandu.common.util.IpUtil;
 import com.sandu.ximon.admin.dto.wxquerydto.WxOrderDto;
@@ -20,10 +24,12 @@
 import com.sandu.ximon.dao.domain.WxConfigEntity;
 import lombok.AllArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
+import me.chanjar.weixin.common.error.WxErrorException;
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import javax.servlet.http.HttpServletRequest;
 import java.text.DecimalFormat;
 import java.text.SimpleDateFormat;
 import java.util.*;
@@ -38,13 +44,12 @@
 public class WxFastPayService {
 
     private final com.github.binarywang.wxpay.service.WxPayService wxPayService;
-    public static final String WECHAT_ORDER_PAY_CALLBACK_URL = "http://49.235.239.118:20012/callback/pay/wechatCallback";
+    public static final String WECHAT_ORDER_PAY_CALLBACK_URL = "http://112.74.63.130:20017/callback/pay/wechatCallback";
     //寰俊璁㈠崟鐘舵�佹煡璇�
     public static final String WECHAT_ORDER_QUETY_URL = "https://api.mch.weixin.qq.com/v3/pay/transactions/out-trade-no/";
     public static final String WECHAT_ORDER_QUETY = "?mchid=";
 
     private final UsrWxPayConfigService wxPayConfigService;
-
 
 
     /**
@@ -74,11 +79,11 @@
      */
     @SuppressWarnings("rawtypes")
     private String createSign(String Key, SortedMap<Object, Object> parameters) {
+
         StringBuffer sb = new StringBuffer();
         Set es = parameters.entrySet();// 鎵�鏈夊弬涓庝紶鍙傜殑鍙傛暟鎸夌収accsii鎺掑簭锛堝崌搴忥級
-        Iterator it = es.iterator();
-        while (it.hasNext()) {
-            Map.Entry entry = (Map.Entry) it.next();
+        for (Object e : es) {
+            Map.Entry entry = (Map.Entry) e;
             String k = (String) entry.getKey();
             Object v = entry.getValue();
             if (null != v && !"".equals(v) && !"sign".equals(k) && !"key".equals(k)) {
@@ -87,11 +92,35 @@
         }
         sb.append("key=" + Key);
         System.out.println("瀛楃涓叉嫾鎺ュ悗鏄�:" + sb.toString());
-        String sign = EncriptionKit.encrypt(sb.toString()).toUpperCase();
-        return sign;
+        return SecureUtil.md5(sb.toString()).toUpperCase();
+//        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(String xmlData) {
+        try {
+            return wxPayService.parseOrderNotifyResult(xmlData);
+        } catch (WxPayException e) {
+            e.printStackTrace();
+            throw new BusinessException("瑙f瀽鍥炶皟缁撴灉澶辫触锛�" + e.getErrCodeDes());
+        }
+    }
+
+
+    public WxPayOrderNotifyResult parseOrderNotifyResult(WxPayService wxPayService, String xmlData) {
         try {
             return wxPayService.parseOrderNotifyResult(xmlData);
         } catch (WxPayException e) {
@@ -201,13 +230,13 @@
      * @return
      */
     @Transactional(rollbackFor = Exception.class)
-    public SortedMap<Object, Object> miniAppPay(String body,
-                                                String orderId, int totalFee, Long poleId) {
+    public SortedMap<Object, Object> miniAppPay(HttpServletRequest request, String body, String orderId, int totalFee, Long poleId, String wxCode) throws WxErrorException {
         WxConfigEntity wxConfig = wxPayConfigService.getConfigByPoleId(poleId);
-        wxConfig.setMchId(wxConfig.getMchId().trim());
+
         //璁剧疆寰俊鏀粯鍙傛暟
         WxPayConfig payConfig = new WxPayConfig();
-        payConfig.setAppId(StringUtils.trimToNull(wxConfig.getAppid()));
+
+        payConfig.setAppId(StringUtils.trimToNull(wxConfig.getAppappid()));
         payConfig.setMchId(StringUtils.trimToNull(wxConfig.getMchId()));
         payConfig.setMchKey(StringUtils.trimToNull(wxConfig.getPrivateKey()));
         payConfig.setSubAppId(StringUtils.trimToNull(null));
@@ -215,16 +244,17 @@
         payConfig.setKeyPath(StringUtils.trimToNull(null));
         wxPayService.setConfig(payConfig);
 
+
         //璁剧疆寰俊鍚屼竴璁㈠崟璇锋眰
         WxPayUnifiedOrderRequest wxPayUnifiedOrderRequest = new WxPayUnifiedOrderRequest();
         wxPayUnifiedOrderRequest.setBody(body);
         wxPayUnifiedOrderRequest.setOutTradeNo(orderId);
         wxPayUnifiedOrderRequest.setTotalFee(totalFee);
-//        wxPayUnifiedOrderRequest.setOpenid("otiM54x_hc_5gbhMY5aZxo7UByNo");
+        wxPayUnifiedOrderRequest.setOpenid(wxCode);
 
 
         wxPayUnifiedOrderRequest.setSignType(WxPayConstants.SignType.MD5);
-        wxPayUnifiedOrderRequest.setSpbillCreateIp(IpUtil.getRealIp());
+        wxPayUnifiedOrderRequest.setSpbillCreateIp(IpUtil.getIpAddr(request));
         wxPayUnifiedOrderRequest.setNotifyUrl(WECHAT_ORDER_PAY_CALLBACK_URL);
         wxPayUnifiedOrderRequest.setTradeType(WxPayConstants.TradeType.JSAPI);
         System.out.println("-----------" + wxPayUnifiedOrderRequest);
@@ -234,20 +264,21 @@
             String time = String.valueOf(System.currentTimeMillis() / 1000);
             if (WxPayConstants.ResultCode.SUCCESS.equals(wxPayUnifiedOrderResult.getResultCode())) {
                 SortedMap<Object, Object> parameters = new TreeMap<>();
-                parameters.put("appid", wxPayUnifiedOrderResult.getAppid());
+                parameters.put("appId", wxPayUnifiedOrderResult.getAppid());
 
-                parameters.put("noncestr", wxPayUnifiedOrderResult.getNonceStr()); // 闅忔満瀛楃涓�
-                parameters.put("partnerid", wxConfig.getMchId()); // 鍟嗘埛id
+                parameters.put("nonceStr", wxPayUnifiedOrderResult.getNonceStr()); // 闅忔満瀛楃涓�
+//                parameters.put("partnerid", wxConfig.getMchId()); // 鍟嗘埛id
 
+                parameters.put("signType", WxPayConstants.SignType.MD5);
                 //  parameters.put("out_trade_no", orderId);//鍟嗘埛璁㈠崟鍙�
-                parameters.put("prepayid", wxPayUnifiedOrderResult.getPrepayId());
-                parameters.put("package", "Sign=WXPay");
-                parameters.put("timestamp", time);
+//                parameters.put("prepayid", wxPayUnifiedOrderResult.getPrepayId());
+                parameters.put("package", "prepay_id=" + wxPayUnifiedOrderResult.getPrepayId());
+                parameters.put("timeStamp", time);
 
                 String sign = createSign(wxConfig.getPrivateKey(), parameters);
 
                 //hashMap.put("paySign", wechatSign);
-                parameters.put("Sign", sign);
+                parameters.put("paySign", sign);
                 return parameters;
             } else {
                 log.error("寰俊鏀粯澶辫触锛寋}", wxPayUnifiedOrderResult.getErrCodeDes());
@@ -259,4 +290,26 @@
         }
     }
 
+
+    public WxMaService getWxMaService(WxConfigEntity wxConfig) {
+        if (wxConfig == null) {
+            throw new BusinessException("鎵句笉鍒板井淇¢厤缃�");
+        }
+        WxMaDefaultConfigImpl config = new WxMaDefaultConfigImpl();
+        config.setAppid(wxConfig.getAppappid());
+        config.setSecret(wxConfig.getAppSecret());
+        WxMaService service = new WxMaServiceImpl();
+        service.setWxMaConfig(config);
+        return service;
+    }
+
+    public String getOpenId(Long poleId, String wxCode) throws WxErrorException {
+        WxConfigEntity userConfig = wxPayConfigService.getConfigByPoleId(poleId);
+        if (userConfig == null) {
+            throw new BusinessException("鎵句笉鍒板井淇¢厤缃�");
+        }
+        WxMaJscode2SessionResult sessionInfo = this.getWxMaService(userConfig).getUserService().getSessionInfo(wxCode);
+        return sessionInfo.getOpenid();
+    }
+
 }

--
Gitblit v1.9.3