From 55e219a5802ab479b9a1c60b2130382a1318ba76 Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期三, 29 六月 2022 09:59:22 +0800
Subject: [PATCH] 充电桩

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/pay/wx/WxFastPayService.java |   56 ++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 46 insertions(+), 10 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..e57c4f6 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.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.dreampie.encription.EncriptionKit;
-import cn.hutool.core.codec.Base64;
 import cn.hutool.http.HttpUtil;
 import com.alibaba.fastjson.JSON;
 import com.github.binarywang.wxpay.bean.notify.WxPayOrderNotifyResult;
@@ -20,6 +23,7 @@
 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;
@@ -44,7 +48,6 @@
     public static final String WECHAT_ORDER_QUETY = "?mchid=";
 
     private final UsrWxPayConfigService wxPayConfigService;
-
 
 
     /**
@@ -201,26 +204,33 @@
      * @return
      */
     @Transactional(rollbackFor = Exception.class)
-    public SortedMap<Object, Object> miniAppPay(String body,
-                                                String orderId, int totalFee, Long poleId) {
-        WxConfigEntity wxConfig = wxPayConfigService.getConfigByPoleId(poleId);
-        wxConfig.setMchId(wxConfig.getMchId().trim());
+    public SortedMap<Object, Object> miniAppPay(String body, String orderId, int totalFee, Long poleId, String wxCode) throws WxErrorException {
+//        WxConfigEntity wxConfig = wxPayConfigService.getConfigByPoleId(poleId);
+        WxConfigEntity wxConfig = new WxConfigEntity();
+        wxConfig.setAppid("wx3d7b3ba37fee07de");
+        wxConfig.setMchId("1536603671");
+        wxConfig.setPrivateKey("0yec5jkwqy4muv5313yn520rdq5cfmqu");
+//        wxConfig.setMchId(wxConfig.getMchId().trim());
         //璁剧疆寰俊鏀粯鍙傛暟
         WxPayConfig payConfig = new WxPayConfig();
-        payConfig.setAppId(StringUtils.trimToNull(wxConfig.getAppid()));
-        payConfig.setMchId(StringUtils.trimToNull(wxConfig.getMchId()));
-        payConfig.setMchKey(StringUtils.trimToNull(wxConfig.getPrivateKey()));
+        payConfig.setAppId(StringUtils.trimToNull("wx3d7b3ba37fee07de"));
+        payConfig.setMchId(StringUtils.trimToNull("1536603671"));
+        payConfig.setMchKey(StringUtils.trimToNull("0yec5jkwqy4muv5313yn520rdq5cfmqu"));
         payConfig.setSubAppId(StringUtils.trimToNull(null));
         payConfig.setSubMchId(StringUtils.trimToNull(null));
         payConfig.setKeyPath(StringUtils.trimToNull(null));
         wxPayService.setConfig(payConfig);
+
+
+        WxMaJscode2SessionResult sessionInfo = this.getWxMaService(wxConfig).getUserService().getSessionInfo(wxCode);
+
 
         //璁剧疆寰俊鍚屼竴璁㈠崟璇锋眰
         WxPayUnifiedOrderRequest wxPayUnifiedOrderRequest = new WxPayUnifiedOrderRequest();
         wxPayUnifiedOrderRequest.setBody(body);
         wxPayUnifiedOrderRequest.setOutTradeNo(orderId);
         wxPayUnifiedOrderRequest.setTotalFee(totalFee);
-//        wxPayUnifiedOrderRequest.setOpenid("otiM54x_hc_5gbhMY5aZxo7UByNo");
+        wxPayUnifiedOrderRequest.setOpenid(sessionInfo.getOpenid());
 
 
         wxPayUnifiedOrderRequest.setSignType(WxPayConstants.SignType.MD5);
@@ -259,4 +269,30 @@
         }
     }
 
+
+    public WxMaService getWxMaService(WxConfigEntity wxConfig) {
+        if (wxConfig == null) {
+            throw new BusinessException("鎵句笉鍒板井淇¢厤缃�");
+        }
+        WxMaDefaultConfigImpl config = new WxMaDefaultConfigImpl();
+        config.setAppid(wxConfig.getAppid());
+        config.setSecret("05edea692eb1b70670ec9ac6e9c62a84");
+        WxMaService service = new WxMaServiceImpl();
+        service.setWxMaConfig(config);
+        return service;
+    }
+
+    public String getOpenId(Long poleId, String wxCode) throws WxErrorException {
+//        WxConfigEntity wxConfig = wxPayConfigService.getConfigByPoleId(poleId);
+        WxConfigEntity wxConfig = new WxConfigEntity();
+        wxConfig.setAppid("wx3d7b3ba37fee07de");
+        wxConfig.setMchId("1536603671");
+        wxConfig.setPrivateKey("0yec5jkwqy4muv5313yn520rdq5cfmqu");
+        if (wxConfig == null) {
+            throw new BusinessException("鎵句笉鍒板井淇¢厤缃�");
+        }
+        WxMaJscode2SessionResult sessionInfo = this.getWxMaService(wxConfig).getUserService().getSessionInfo(wxCode);
+        return sessionInfo.getOpenid();
+    }
+
 }

--
Gitblit v1.9.3