From 39bd9f965dfb48925a66fcd80787144b7541b866 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期日, 09 二月 2025 18:30:30 +0800
Subject: [PATCH] bug修改

---
 src/main/java/com/taoke/autopay/utils/order/OrderChannelApiUtil.java |   41 ++++++++++++++++++++++++++++++++++-------
 1 files changed, 34 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/taoke/autopay/utils/order/OrderChannelApiUtil.java b/src/main/java/com/taoke/autopay/utils/order/OrderChannelApiUtil.java
index 9266f72..2365766 100644
--- a/src/main/java/com/taoke/autopay/utils/order/OrderChannelApiUtil.java
+++ b/src/main/java/com/taoke/autopay/utils/order/OrderChannelApiUtil.java
@@ -2,13 +2,20 @@
 
 import com.taoke.autopay.entity.OrderChannelEnum;
 import com.taoke.autopay.utils.HttpUtil;
-import com.taoke.autopay.utils.StringUtil;
+import net.sf.json.JSONArray;
 import net.sf.json.JSONObject;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
 import java.io.UnsupportedEncodingException;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.net.URLEncoder;
+import java.nio.charset.StandardCharsets;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Set;
 
 /**
  * @author hxh
@@ -28,15 +35,35 @@
      * @param: channel
      * @param: orderChannelName
      **/
-    public static boolean isMerchantCanPay(OrderChannelEnum channel, String merchant) throws UnsupportedEncodingException {
+    public static boolean isMerchantCanPay(OrderChannelEnum channel, String merchant, BigDecimal payMoney) throws UnsupportedEncodingException {
         if (channel == OrderChannelEnum.cyx) {
             String url = String.format("https://api.youihuo.com/open/free.checkKsCompanyName?bsName=%s&apiKey=%s", URLEncoder.encode(merchant, "UTF-8"), OrderChannelUtil.CYX_API_KEY);
-            String result =  HttpUtil.get(url);
-            logger.info(String.format("瓒呬剑浜晢瀹朵粯娆惧垽鏂細%s-%s", merchant, result));
-            JSONObject root =   JSONObject.fromObject(result);
+            String result = HttpUtil.get(url);
+            logger.info(String.format("瓒呬剑浜晢瀹朵粯娆惧垽鏂細%s-%s-%s", merchant, result, payMoney!=null?payMoney.setScale(2,RoundingMode.HALF_UP).toString():null));
+            JSONObject root = JSONObject.fromObject(result);
             System.out.println(result);
-            if(root.optInt("code") == 1000){
+            if (root.optInt("code") == 1000) {
                 return true;
+            }
+        } else if (channel == OrderChannelEnum.bps) {
+            String url = String.format("https://api.bpshe.com/mall/douyinOMS/getSubsidyOrderInfo?appKey=cdaef330f1324961a73e15a85ab67fd2&payAccount=%s", URLEncoder.encode(merchant, StandardCharsets.UTF_8.displayName()));
+            Map<String, String> headers = new HashMap<>();
+            headers.put("Accept", "application/json;charset=utf-8");
+            String result = HttpUtil.get(url, headers);
+            logger.info(String.format("鐖嗗搧绀惧晢瀹朵粯娆惧垽鏂細%s-%s-%s", merchant, result, payMoney!=null?payMoney.setScale(2,RoundingMode.HALF_UP).toString():null));
+            JSONObject root = JSONObject.fromObject(result);
+            if (root.optInt("errCode") == 0) {
+                JSONArray array = root.optJSONObject("data").optJSONArray("payAmounts");
+                if (array != null) {
+                    if (payMoney == null) {
+                        return true;
+                    }
+                    Set<String> moneys = new HashSet<>();
+                    for (int i = 0; i < array.size(); i++) {
+                        moneys.add(array.optString(i));
+                    }
+                    return moneys.contains(payMoney.setScale(2, RoundingMode.HALF_UP).toString());
+                }
             }
         }
         return false;
@@ -44,7 +71,7 @@
 
     public static void main(String[] args) throws UnsupportedEncodingException {
 
-     System.out.print(   isMerchantCanPay(OrderChannelEnum.cyx,"骞垮窞甯傚ぉ娌冲尯闀垮叴琛楀畨灏旈泤鏈嶉グ鍟嗚1"));
+
     }
 
 

--
Gitblit v1.8.0