From 2778cf2a16823f9b1153a0549b47f7b503176a17 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期六, 12 九月 2020 18:04:43 +0800
Subject: [PATCH] 爱奇艺正片,搜索引擎

---
 src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java |   54 +++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 43 insertions(+), 11 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..6d0fc91 100644
--- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
+++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
@@ -8,6 +8,8 @@
 
 import com.yeshi.buwan.domain.DetailSystem;
 import com.yeshi.buwan.service.imp.SystemService;
+import com.yeshi.buwan.util.IPUtil;
+import com.yeshi.buwan.util.StringUtil;
 import com.yeshi.buwan.vo.AcceptData;
 import org.springframework.stereotype.Controller;
 
@@ -24,29 +26,59 @@
     @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");
+    private String getAdShowType(String key, String channel, int version, Map<String, String> map) {
+        String splash = map.get(key);
         JSONObject jsonObject = JSONObject.fromObject(splash);
         ADConfig splashAD = null;
+        channel = channel.toLowerCase();
         if (jsonObject.optJSONObject(channel) == null) {
             // 榛樿涓哄簲鐢ㄥ疂
             channel = "qq";
         }
-        String splashAdType = "";
+        String adType = "";
         splashAD = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
-        if (Integer.parseInt(version) >= splashAD.getVersion()) {
-            splashAdType = "";
+        if (version >= splashAD.getVersion()) {
+            adType = "";
         } else {
-            splashAdType = splashAD.getType();
+            adType = splashAD.getType();
         }
 
+        return adType;
+    }
+
+    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);
+
+        String ip = IPUtil.getRemotIP(request);
+        String splash = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
+
+
+        //寮�灞忕殑鍦板尯灞忚斀瑙勫垯
+        String shieldProvince = map.get("shield_province");
+        if(!StringUtil.isNullOrEmpty(shieldProvince)) {
+            JSONObject json = JSONObject.fromObject(shieldProvince);
+            //鑾峰彇娓犻亾闇�瑕佸睆钄界殑鍩庡競
+            String province = json.optString(acceptData.getChannel().toLowerCase());
+            if (!StringUtil.isNullOrEmpty(splash) && !StringUtil.isNullOrEmpty(province)) {
+                String pro = IPUtil.getIPProvince(ip);
+                if (pro != null && pro.contains(province)) {//灞忚斀IP
+                    splash = "";
+                }
+            }
+        }
+
+        //寮�灞�
+        ad.put("splash", splash);
+
+
+        //瑙嗛鍓嶈创
+        ad.put("videoPlayPre", getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map));
+        //APP閫�鍑�
+        ad.put("exitApp", getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map));
+
         data.put("ad", ad);
         out.print(JsonUtil.loadTrueJson(data.toString()));
     }

--
Gitblit v1.8.0