Procházet zdrojové kódy

优化业主版支付问题

java110 před 5 roky
rodič
revize
3b13fd51fe

+ 19 - 23
service-front/src/main/java/com/java110/front/smo/AppAbstractComponentSMO.java

@@ -1,8 +1,9 @@
 package com.java110.front.smo;
 package com.java110.front.smo;
 
 
-import com.java110.front.properties.WechatAuthProperties;
 import com.java110.core.component.AbstractComponentSMO;
 import com.java110.core.component.AbstractComponentSMO;
 import com.java110.core.context.IPageData;
 import com.java110.core.context.IPageData;
+import com.java110.dto.smallWeChat.SmallWeChatDto;
+import com.java110.front.properties.WechatAuthProperties;
 import com.java110.utils.cache.MappingCache;
 import com.java110.utils.cache.MappingCache;
 import com.java110.utils.constant.CommonConstant;
 import com.java110.utils.constant.CommonConstant;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.Assert;
@@ -50,7 +51,7 @@ public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
         try {
         try {
             responseEntity = restTemplate.exchange(url, httpMethod, httpEntity, String.class);
             responseEntity = restTemplate.exchange(url, httpMethod, httpEntity, String.class);
         } catch (HttpStatusCodeException e) { //这里spring 框架 在4XX 或 5XX 时抛出 HttpServerErrorException 异常,需要重新封装一下
         } catch (HttpStatusCodeException e) { //这里spring 框架 在4XX 或 5XX 时抛出 HttpServerErrorException 异常,需要重新封装一下
-            responseEntity = new ResponseEntity<String>( e.getResponseBodyAsString(), e.getStatusCode());
+            responseEntity = new ResponseEntity<String>(e.getResponseBodyAsString(), e.getStatusCode());
         } catch (Exception e) {
         } catch (Exception e) {
             responseEntity = new ResponseEntity<String>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
             responseEntity = new ResponseEntity<String>(e.getMessage(), HttpStatus.INTERNAL_SERVER_ERROR);
         } finally {
         } finally {
@@ -72,7 +73,7 @@ public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
     protected Map<String, String> java110Payment(RestTemplate outRestTemplate,
     protected Map<String, String> java110Payment(RestTemplate outRestTemplate,
                                                  String feeName, String tradeType,
                                                  String feeName, String tradeType,
                                                  String orderNum, double money,
                                                  String orderNum, double money,
-                                                 String openId,String payAppId,String payMchId) throws Exception {
+                                                 String openId, SmallWeChatDto smallWeChatDto) throws Exception {
         logger.info("【小程序支付】 统一下单开始, 订单编号=" + orderNum);
         logger.info("【小程序支付】 统一下单开始, 订单编号=" + orderNum);
         SortedMap<String, String> resultMap = new TreeMap<String, String>();
         SortedMap<String, String> resultMap = new TreeMap<String, String>();
 //生成支付金额,开发环境处理支付金额数到0.01、0.02、0.03元
 //生成支付金额,开发环境处理支付金额数到0.01、0.02、0.03元
@@ -80,31 +81,24 @@ public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
         double payAmount = PayUtil.getPayAmountByEnv(MappingCache.getValue("HC_ENV"), money);
         double payAmount = PayUtil.getPayAmountByEnv(MappingCache.getValue("HC_ENV"), money);
 //添加或更新支付记录(参数跟进自己业务需求添加)
 //添加或更新支付记录(参数跟进自己业务需求添加)
 
 
-        Map<String, String> resMap = this.java110UnifieldOrder(outRestTemplate,feeName, orderNum, tradeType, payAmount, openId);
+        Map<String, String> resMap = this.java110UnifieldOrder(outRestTemplate, feeName, orderNum, tradeType, payAmount, openId,smallWeChatDto);
         if ("SUCCESS".equals(resMap.get("return_code")) && "SUCCESS".equals(resMap.get("result_code"))) {
         if ("SUCCESS".equals(resMap.get("return_code")) && "SUCCESS".equals(resMap.get("result_code"))) {
-            if(WechatAuthProperties.TRADE_TYPE_JSAPI.equals(tradeType)) {
-                if(payAppId != null){
-                    resultMap.put("appId", payAppId);
-                }else{
-                    resultMap.put("appId", wechatAuthProperties.getAppId());
-                }
-                if(payMchId != null){
-                    resultMap.put("sign", PayUtil.createSign(resultMap, payMchId));
-                }else{
-                    resultMap.put("sign", PayUtil.createSign(resultMap, wechatAuthProperties.getKey()));
-                }
+            if (WechatAuthProperties.TRADE_TYPE_JSAPI.equals(tradeType)) {
+
+                resultMap.put("appId", smallWeChatDto.getAppId());
+                resultMap.put("sign", PayUtil.createSign(resultMap, smallWeChatDto.getPayPassword()));
                 resultMap.put("timeStamp", PayUtil.getCurrentTimeStamp());
                 resultMap.put("timeStamp", PayUtil.getCurrentTimeStamp());
                 resultMap.put("nonceStr", PayUtil.makeUUID(32));
                 resultMap.put("nonceStr", PayUtil.makeUUID(32));
                 resultMap.put("package", "prepay_id=" + resMap.get("prepay_id"));
                 resultMap.put("package", "prepay_id=" + resMap.get("prepay_id"));
                 resultMap.put("signType", "MD5");
                 resultMap.put("signType", "MD5");
-            }else if(WechatAuthProperties.TRADE_TYPE_APP.equals(tradeType)){
-                resultMap.put("appId", wechatAuthProperties.getAppId());
+            } else if (WechatAuthProperties.TRADE_TYPE_APP.equals(tradeType)) {
+                resultMap.put("appId", smallWeChatDto.getAppId());
                 resultMap.put("timeStamp", PayUtil.getCurrentTimeStamp());
                 resultMap.put("timeStamp", PayUtil.getCurrentTimeStamp());
                 resultMap.put("nonceStr", PayUtil.makeUUID(32));
                 resultMap.put("nonceStr", PayUtil.makeUUID(32));
-                resultMap.put("partnerid", wechatAuthProperties.getMchId());
+                resultMap.put("partnerid", smallWeChatDto.getMchId());
                 resultMap.put("prepayid", resMap.get("prepay_id"));
                 resultMap.put("prepayid", resMap.get("prepay_id"));
                 //resultMap.put("signType", "MD5");
                 //resultMap.put("signType", "MD5");
-                resultMap.put("sign", PayUtil.createSign(resultMap, wechatAuthProperties.getKey()));
+                resultMap.put("sign", PayUtil.createSign(resultMap, smallWeChatDto.getPayPassword()));
             }
             }
             resultMap.put("code", "0");
             resultMap.put("code", "0");
             resultMap.put("msg", "下单成功");
             resultMap.put("msg", "下单成功");
@@ -120,11 +114,13 @@ public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
     /**
     /**
      * 小程序支付统一下单
      * 小程序支付统一下单
      */
      */
-    private Map<String, String> java110UnifieldOrder(RestTemplate outRestTemplate, String feeName, String orderNum, String tradeType, double payAmount, String openid) throws Exception {
+    private Map<String, String> java110UnifieldOrder(RestTemplate outRestTemplate, String feeName, String orderNum,
+                                                     String tradeType, double payAmount, String openid,
+                                                     SmallWeChatDto smallWeChatDto) throws Exception {
 //封装参数
 //封装参数
         SortedMap<String, String> paramMap = new TreeMap<String, String>();
         SortedMap<String, String> paramMap = new TreeMap<String, String>();
-        paramMap.put("appid", wechatAuthProperties.getAppId());
-        paramMap.put("mch_id", wechatAuthProperties.getMchId());
+        paramMap.put("appid", smallWeChatDto.getAppId());
+        paramMap.put("mch_id", smallWeChatDto.getMchId());
         paramMap.put("nonce_str", PayUtil.makeUUID(32));
         paramMap.put("nonce_str", PayUtil.makeUUID(32));
         paramMap.put("body", "HC智慧家园-" + feeName);
         paramMap.put("body", "HC智慧家园-" + feeName);
         paramMap.put("out_trade_no", orderNum);
         paramMap.put("out_trade_no", orderNum);
@@ -133,7 +129,7 @@ public abstract class AppAbstractComponentSMO extends AbstractComponentSMO {
         paramMap.put("notify_url", wechatAuthProperties.getWxNotifyUrl());
         paramMap.put("notify_url", wechatAuthProperties.getWxNotifyUrl());
         paramMap.put("trade_type", tradeType);
         paramMap.put("trade_type", tradeType);
         paramMap.put("openid", openid);
         paramMap.put("openid", openid);
-        paramMap.put("sign", PayUtil.createSign(paramMap, wechatAuthProperties.getKey()));
+        paramMap.put("sign", PayUtil.createSign(paramMap, smallWeChatDto.getPayPassword()));
 //转换为xml
 //转换为xml
         String xmlData = PayUtil.mapToXml(paramMap);
         String xmlData = PayUtil.mapToXml(paramMap);
 
 

+ 43 - 4
service-front/src/main/java/com/java110/front/smo/payment/impl/ToPaySMOImpl.java

@@ -1,12 +1,16 @@
 package com.java110.front.smo.payment.impl;
 package com.java110.front.smo.payment.impl;
 
 
+import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
 import com.alibaba.fastjson.JSONObject;
+import com.java110.core.context.IPageData;
+import com.java110.core.context.PageData;
+import com.java110.dto.smallWeChat.SmallWeChatDto;
 import com.java110.front.properties.WechatAuthProperties;
 import com.java110.front.properties.WechatAuthProperties;
 import com.java110.front.smo.AppAbstractComponentSMO;
 import com.java110.front.smo.AppAbstractComponentSMO;
 import com.java110.front.smo.payment.IToPaySMO;
 import com.java110.front.smo.payment.IToPaySMO;
-import com.java110.core.context.IPageData;
 import com.java110.utils.constant.ServiceConstant;
 import com.java110.utils.constant.ServiceConstant;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
 import org.slf4j.Logger;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -55,6 +59,17 @@ public class ToPaySMOImpl extends AppAbstractComponentSMO implements IToPaySMO {
     protected ResponseEntity<String> doBusinessProcess(IPageData pd, JSONObject paramIn) throws Exception {
     protected ResponseEntity<String> doBusinessProcess(IPageData pd, JSONObject paramIn) throws Exception {
 
 
         ResponseEntity responseEntity = null;
         ResponseEntity responseEntity = null;
+
+        SmallWeChatDto smallWeChatDto = getSmallWechat(pd, paramIn);
+
+        if (smallWeChatDto == null) { //从配置文件中获取 小程序配置信息
+            smallWeChatDto = new SmallWeChatDto();
+            smallWeChatDto.setAppId(wechatAuthProperties.getAppId());
+            smallWeChatDto.setAppSecret(wechatAuthProperties.getSecret());
+            smallWeChatDto.setMchId(wechatAuthProperties.getMchId());
+            smallWeChatDto.setPayPassword(wechatAuthProperties.getKey());
+        }
+
         //查询用户ID
         //查询用户ID
         paramIn.put("userId", pd.getUserId());
         paramIn.put("userId", pd.getUserId());
         String url = ServiceConstant.SERVICE_API_URL + "/api/fee.payFeePre";
         String url = ServiceConstant.SERVICE_API_URL + "/api/fee.payFeePre";
@@ -84,16 +99,40 @@ public class ToPaySMOImpl extends AppAbstractComponentSMO implements IToPaySMO {
         JSONObject realUserInfo = userResult.getJSONArray("users").getJSONObject(0);
         JSONObject realUserInfo = userResult.getJSONArray("users").getJSONObject(0);
 
 
         String openId = realUserInfo.getString("openId");
         String openId = realUserInfo.getString("openId");
-        String payAppId = orderInfo.getString("payAppId");
-        String payMchId = orderInfo.getString("payMchId");
+//        String payAppId = orderInfo.getString("payAppId");
+//        String payMchId = orderInfo.getString("payMchId");
 
 
 
 
-        Map result = super.java110Payment(outRestTemplate,paramIn.getString("feeName"),paramIn.getString("tradeType"), orderId, money, openId,payAppId,payMchId);
+        Map result = super.java110Payment(outRestTemplate, paramIn.getString("feeName"), paramIn.getString("tradeType"), orderId, money, openId, smallWeChatDto);
         responseEntity = new ResponseEntity(JSONObject.toJSONString(result), HttpStatus.OK);
         responseEntity = new ResponseEntity(JSONObject.toJSONString(result), HttpStatus.OK);
 
 
         return responseEntity;
         return responseEntity;
     }
     }
 
 
 
 
+    private SmallWeChatDto getSmallWechat(IPageData pd, JSONObject paramIn) {
+
+        ResponseEntity responseEntity = null;
+
+        pd = PageData.newInstance().builder(pd.getUserId(), "", "", pd.getReqData(),
+                "", "", "", "",
+                pd.getAppId());
+        responseEntity = this.callCenterService(restTemplate, pd, "",
+                ServiceConstant.SERVICE_API_URL + "/api/smallWeChat.listSmallWeChats?appId="
+                        + paramIn.getString("appId") + "&page=1&row=1", HttpMethod.GET);
+
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return null;
+        }
+        JSONObject smallWechatObj = JSONObject.parseObject(responseEntity.getBody().toString());
+        JSONArray smallWeChats = smallWechatObj.getJSONArray("smallWeChats");
+
+        if (smallWeChats == null || smallWeChats.size() < 1) {
+            return null;
+        }
+
+        return BeanConvertUtil.covertBean(smallWeChats.get(0), SmallWeChatDto.class);
+    }
+
 
 
 }
 }