From cbc9ffb792e29beddf15dbfa70437bfc40de5baa Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期一, 25 一月 2021 17:18:15 +0800
Subject: [PATCH] 完善微信H5支付功能

---
 src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java |  132 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 118 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
index 2bfb4e6..3006c7d 100644
--- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
+++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
@@ -1,14 +1,25 @@
 package com.yeshi.buwan.controller.parser;
 
 import java.io.PrintWriter;
+import java.util.List;
 import java.util.Map;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 
+import com.google.gson.GsonBuilder;
+import com.google.gson.annotations.Expose;
+import com.yeshi.buwan.domain.Config;
 import com.yeshi.buwan.domain.DetailSystem;
+import com.yeshi.buwan.domain.recommend.FloatAD;
+import com.yeshi.buwan.log.LogHelper;
 import com.yeshi.buwan.service.imp.SystemService;
+import com.yeshi.buwan.service.inter.ad.FloatADService;
+import com.yeshi.buwan.util.IPUtil;
+import com.yeshi.buwan.util.StringUtil;
 import com.yeshi.buwan.vo.AcceptData;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Controller;
 
 import com.google.gson.Gson;
@@ -19,41 +30,127 @@
 
 @Controller
 public class ConfigParser {
+
+    Logger logger = LoggerFactory.getLogger(ConfigParser.class);
     @Resource
     private ConfigService configService;
     @Resource
     private SystemService systemService;
 
-    public void getConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
-        String channel = request.getParameter("Channel");
-        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
-        String version = request.getParameter("Version");
-        Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
-        String splash = map.get("ad_splash_config");
+    @Resource
+    private FloatADService floatADService;
+
+    public ADConfig getAdShowType(String key, String channel, int version, Map<String, String> map) {
+        String splash = map.get(key);
         JSONObject jsonObject = JSONObject.fromObject(splash);
-        ADConfig splashAD = null;
+        ADConfig adConfig = null;
+        channel = channel.toLowerCase();
         if (jsonObject.optJSONObject(channel) == null) {
             // 榛樿涓哄簲鐢ㄥ疂
             channel = "qq";
         }
-        String splashAdType = "";
-        splashAD = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
-        if (Integer.parseInt(version) >= splashAD.getVersion()) {
-            splashAdType = "";
-        } else {
-            splashAdType = splashAD.getType();
+        adConfig = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
+        if (version >= adConfig.getVersion()) {
+            adConfig = null;
         }
 
+        return adConfig;
+    }
+
+    public void getConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
+        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
+        Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
         JSONObject data = new JSONObject();
         JSONObject ad = new JSONObject();
-        ad.put("splash", splashAdType);
+        JSONObject adNew = new JSONObject();
+
+        String ip = IPUtil.getRemotIP(request);
+        ADConfig splashConfig = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
+
+
+        //寮�灞忕殑鍦板尯灞忚斀瑙勫垯
+        String shieldProvince = map.get("shield_province");
+        boolean hidden = false;
+        if (!StringUtil.isNullOrEmpty(shieldProvince)) {
+            JSONObject json = JSONObject.fromObject(shieldProvince);
+            //鑾峰彇娓犻亾闇�瑕佸睆钄界殑鍩庡競
+            String province = json.optString(acceptData.getChannel().toLowerCase());
+            if (splashConfig != null && !StringUtil.isNullOrEmpty(province)) {
+                String pro = IPUtil.getIPProvince(ip);
+                LogHelper.print("鍩庡競灞忚斀锛�" + ip + ":" + pro);
+                if (pro != null && pro.contains(province)) {//灞忚斀IP
+                    hidden = true;
+                    LogHelper.print("鍩庡競灞忚斀:" + pro);
+                }
+            }
+        }
+
+        if (hidden)
+            splashConfig = null;
+
+        String splash = "";
+        if (splashConfig != null)
+            splash = splashConfig.getType();
+
+        Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
+
+        //寮�灞�
+        ad.put("splash", splash);
+        adNew.put("splash", gson.toJson(splashConfig));
+
+
+        ADConfig adConfig = null;
+        //瑙嗛鍓嶈创
+        adConfig = getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map);
+        ad.put("videoPlayPre", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoPlayPre", gson.toJson(adConfig));
+        //APP閫�鍑�
+        adConfig = getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map);
+        ad.put("exitApp", adConfig == null ? "" : adConfig.getType());
+        adNew.put("exitApp", gson.toJson(adConfig));
+        //鍏ㄥ睆骞垮憡鎺у埗
+        adConfig = getAdShowType("ad_video_detail_full_video", acceptData.getChannel(), acceptData.getVersion(), map);
+        ad.put("videoDetailFullVideo", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoDetailFullVideo", gson.toJson(adConfig));
+        //鎼滅储椤靛箍鍛婃帶鍒�
+        adConfig = getAdShowType("ad_video_search", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hidden)
+            adConfig = null;
+        ad.put("videoSearch", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoSearch", gson.toJson(adConfig));
+
         data.put("ad", ad);
+        data.put("adNew", adNew);
+        out.print(JsonUtil.loadTrueJson(data.toString()));
+    }
+
+
+    /**
+     * 鑾峰彇棣栭〉閰嶇疆淇℃伅
+     *
+     * @param acceptData
+     * @param request
+     * @param out
+     */
+    public void getHomeConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
+        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
+        List<FloatAD> adList = floatADService.listShowAD(1, 1);
+        Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
+        JSONObject data = new JSONObject();
+        if (adList != null && adList.size() > 0) {
+            FloatAD ad = adList.get(0);
+            data.put("floatAD", gson.toJson(ad));
+        }
+
         out.print(JsonUtil.loadTrueJson(data.toString()));
     }
 
     class ADConfig {
         int version;
+        @Expose
         String type;
+        @Expose
+        String pid;
 
         public int getVersion() {
             return version;
@@ -71,6 +168,13 @@
             this.type = type;
         }
 
+        public String getPid() {
+            return pid;
+        }
+
+        public void setPid(String pid) {
+            this.pid = pid;
+        }
     }
 
 }

--
Gitblit v1.8.0