From 0a18a8cb0a7a57bf1f82df425251334c57f8c39a Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期六, 23 一月 2021 15:40:37 +0800
Subject: [PATCH] 新增手机号/qq/微信绑定

---
 src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java |  102 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 87 insertions(+), 15 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 6d0fc91..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,16 +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;
@@ -21,29 +30,31 @@
 
 @Controller
 public class ConfigParser {
+
+    Logger logger = LoggerFactory.getLogger(ConfigParser.class);
     @Resource
     private ConfigService configService;
     @Resource
     private SystemService systemService;
 
-    private String getAdShowType(String key, String channel, int version, Map<String, String> map) {
+    @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 adType = "";
-        splashAD = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
-        if (version >= splashAD.getVersion()) {
-            adType = "";
-        } else {
-            adType = splashAD.getType();
+        adConfig = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
+        if (version >= adConfig.getVersion()) {
+            adConfig = null;
         }
 
-        return adType;
+        return adConfig;
     }
 
     public void getConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
@@ -51,41 +62,95 @@
         Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
         JSONObject data = new JSONObject();
         JSONObject ad = new JSONObject();
+        JSONObject adNew = new JSONObject();
 
         String ip = IPUtil.getRemotIP(request);
-        String splash = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
+        ADConfig splashConfig = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
 
 
         //寮�灞忕殑鍦板尯灞忚斀瑙勫垯
         String shieldProvince = map.get("shield_province");
-        if(!StringUtil.isNullOrEmpty(shieldProvince)) {
+        boolean hidden = false;
+        if (!StringUtil.isNullOrEmpty(shieldProvince)) {
             JSONObject json = JSONObject.fromObject(shieldProvince);
             //鑾峰彇娓犻亾闇�瑕佸睆钄界殑鍩庡競
             String province = json.optString(acceptData.getChannel().toLowerCase());
-            if (!StringUtil.isNullOrEmpty(splash) && !StringUtil.isNullOrEmpty(province)) {
+            if (splashConfig != null && !StringUtil.isNullOrEmpty(province)) {
                 String pro = IPUtil.getIPProvince(ip);
+                LogHelper.print("鍩庡競灞忚斀锛�" + ip + ":" + pro);
                 if (pro != null && pro.contains(province)) {//灞忚斀IP
-                    splash = "";
+                    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;
         //瑙嗛鍓嶈创
-        ad.put("videoPlayPre", getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map));
+        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閫�鍑�
-        ad.put("exitApp", getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map));
+        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;
@@ -103,6 +168,13 @@
             this.type = type;
         }
 
+        public String getPid() {
+            return pid;
+        }
+
+        public void setPid(String pid) {
+            this.pid = pid;
+        }
     }
 
 }

--
Gitblit v1.8.0