From 010ef2a907e66efd4702443c06cdd18f8a7ffa5b Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 30 十月 2024 14:08:53 +0800
Subject: [PATCH] IP归属地查询接口集成

---
 src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java |  303 +++++++++++++++++++++++++++----------------------
 1 files changed, 167 insertions(+), 136 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 87af938..8662171 100644
--- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
+++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
@@ -1,41 +1,50 @@
 package com.yeshi.buwan.controller.parser;
 
-import java.io.PrintWriter;
-import java.lang.reflect.Type;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-
-import javax.annotation.Resource;
-import javax.servlet.http.HttpServletRequest;
-
+import com.google.gson.Gson;
 import com.google.gson.GsonBuilder;
 import com.google.gson.annotations.Expose;
-import com.google.gson.reflect.TypeToken;
-import com.yeshi.buwan.domain.system.DetailSystem;
+import com.yeshi.buwan.domain.ad.AdAreaConfig;
+import com.yeshi.buwan.domain.ad.ThirdAdType;
 import com.yeshi.buwan.domain.recommend.FloatAD;
-import com.yeshi.buwan.dto.config.ADShieldIPConfig;
-import com.yeshi.buwan.log.LogHelper;
+import com.yeshi.buwan.domain.system.DetailSystem;
+import com.yeshi.buwan.dto.log.BaseLog;
+import com.yeshi.buwan.service.imp.DetailSystemConfigService;
 import com.yeshi.buwan.service.imp.SystemService;
+import com.yeshi.buwan.service.inter.ad.AdAreaConfigService;
 import com.yeshi.buwan.service.inter.ad.FloatADService;
+import com.yeshi.buwan.service.inter.system.SystemConfigService;
+import com.yeshi.buwan.service.inter.user.UserDPContentWatchStatisticService;
+import com.yeshi.buwan.service.manager.APPManager;
 import com.yeshi.buwan.service.manager.IPManager;
 import com.yeshi.buwan.util.IPUtil;
+import com.yeshi.buwan.util.JsonUtil;
 import com.yeshi.buwan.util.StringUtil;
+import com.yeshi.buwan.util.ad.AdAreaUtil;
+import com.yeshi.buwan.util.log.LoggerUtil;
+import com.yeshi.buwan.util.log.UserActiveLogFactory;
 import com.yeshi.buwan.vo.AcceptData;
+import com.yeshi.buwan.vo.ad.AdConfigTypeVO;
+import net.sf.json.JSONObject;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Controller;
 
-import com.google.gson.Gson;
-import com.yeshi.buwan.service.imp.DetailSystemConfigService;
-import com.yeshi.buwan.util.JsonUtil;
-
-import net.sf.json.JSONObject;
+import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
+import java.io.PrintWriter;
+import java.math.BigDecimal;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
 
 @Controller
 public class ConfigParser {
 
+
     Logger logger = LoggerFactory.getLogger(ConfigParser.class);
+
+    Logger debugLogger = LoggerFactory.getLogger("debug");
+
     @Resource
     private DetailSystemConfigService configService;
     @Resource
@@ -47,163 +56,183 @@
     @Resource
     private IPManager ipManager;
 
+    @Resource
+    private SystemConfigService systemConfigService;
+
+    @Resource
+    private UserDPContentWatchStatisticService userDPContentWatchStatisticService;
+
+    @Resource
+    private APPManager appManager;
+
+    @Resource
+    private AdAreaConfigService adAreaConfigService;
+
+
     public ADConfig getAdShowType(String key, String channel, int version, Map<String, String> map) {
         String splash = map.get(key);
         JSONObject jsonObject = JSONObject.fromObject(splash);
+        if (jsonObject == null || jsonObject.isEmpty())
+            return null;
         ADConfig adConfig = null;
         channel = channel.toLowerCase();
-        if (jsonObject.optJSONObject(channel) == null) {
+        if (jsonObject == null || jsonObject.optJSONObject(channel) == null) {
             // 榛樿涓哄簲鐢ㄥ疂
             channel = "qq";
         }
-        adConfig = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
+        JSONObject channelAd = jsonObject.optJSONObject(channel);
+        adConfig = new Gson().fromJson(channelAd.toString(), ADConfig.class);
         if (version >= adConfig.getVersion()) {
             adConfig = null;
         }
+        //鏍煎紡濡備笅:
+        //{"typeProperties":{"csj":{"weight":1,"pid":"123123"},"gdt":{"weight":1,"pid":"123123"}}}
+        if (adConfig != null && channelAd.optJSONObject("typeProbability") != null) {
+            JSONObject properties = channelAd.optJSONObject("typeProbability");
+
+            BigDecimal total = new BigDecimal(0);
+            for (Iterator<String> its = properties.keys(); its.hasNext(); ) {
+                String k = its.next();
+                total = total.add(new BigDecimal(properties.optJSONObject(k).optString("weight")));
+            }
+            BigDecimal random = total.multiply(new BigDecimal(Math.random()));
+            total = new BigDecimal(0);
+            for (Iterator<String> its = properties.keys(); its.hasNext(); ) {
+                String k = its.next();
+                total = total.add(new BigDecimal(properties.optJSONObject(k).optString("weight")));
+                if (random.compareTo(total) < 0) {
+                    adConfig.setPid(properties.optJSONObject(k).optString("pid"));
+                    adConfig.setType(k);
+                    break;
+                }
+            }
+
+        }
+
 
         return adConfig;
     }
 
-    /**
-     * 灞忚斀鎵�鏈夌殑骞垮憡
-     *
-     * @param channel
-     * @param version
-     * @param shieldInfo
-     * @param ip
-     * @return
-     */
-    private boolean shieldAllAd(String channel, Integer version, String shieldInfo, String ip) {
-        if (StringUtil.isNullOrEmpty(shieldInfo)) {
-            return false;
+
+    // 鑾峰彇骞垮憡閰嶇疆淇℃伅
+    private void loadAdConfig(AcceptData acceptData, Map<String, String> map, String ip, boolean isDPUser, JSONObject data) {
+        Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
+        // 鑾峰彇鍖哄煙灞忚斀淇℃伅
+        List<AdAreaConfig> areaConfigList = null;
+        try {
+            areaConfigList = adAreaConfigService.listCache(acceptData.getChannel(), Long.parseLong(acceptData.getDetailSystem().getId()));
+        } catch (Exception e) {
+
         }
-        Type type = new TypeToken<List<ADShieldIPConfig>>() {
-        }.getType();
-        List<ADShieldIPConfig> list = new Gson().fromJson(shieldInfo, type);
-        Map<String, ADShieldIPConfig.IPShieldRule> map = new HashMap<>();
-        for (ADShieldIPConfig config : list) {
-            map.put(config.getChannel().toLowerCase(), config.getRule());
-        }
-        if (map.get(channel.toLowerCase()) != null) {
-            ADShieldIPConfig.IPShieldRule rule = map.get(channel.toLowerCase());
-            if (version >= rule.getVersion()) {
-                //璇锋眰
-                IPUtil.IPInfo ipInfo = null;
-                try {
-                    ipInfo = ipManager.getIPInfo(ip);
-                } catch (Exception e) {
-                    e.printStackTrace();
-                }
+        IPUtil.IPInfo ipInfo = null;
+        if (areaConfigList != null && areaConfigList.size() > 0) {
+            try {
+                ipInfo = ipManager.getIPInfo(ip);
                 if (ipInfo != null) {
-                    //鍏堝垽鏂渷
-                    if (!StringUtil.isNullOrEmpty(rule.getProvince())) {
-                        if (ipInfo.getProvince() != null && ipInfo.getProvince().contains(rule.getProvince())) {
-                            if (!StringUtil.isNullOrEmpty(rule.getCity())) {//鍚屾椂鍒ゆ柇鐪佸拰甯�
-                                if (ipInfo.getCity() != null && ipInfo.getCity().contains(rule.getCity())) {
-                                    return true;
-                                }
-                            } else {
-                                //鍙垽鏂渷
-                                return true;
-                            }
-                        }
-                    } else if (!StringUtil.isNullOrEmpty(rule.getCity())) {
-                        //鍙垽鏂競
-                        if (ipInfo.getCity() != null && ipInfo.getCity().contains(rule.getCity())) {
-                            return true;
-                        }
+                    debugLogger.info("IP褰掑睘鍦帮細IP-{},鐗堟湰-{}, 娓犻亾-{}锛岀渷-{}锛� 甯�-{}", ip, acceptData.getVersion(), acceptData.getChannel(), ipInfo.getProvince(), ipInfo.getCity());
+                }
+            } catch (Exception e) {
+                e.printStackTrace();
+                logger.error("IP鍦板潃浣嶇疆淇℃伅鑾峰彇澶辫触锛�" + ip);
+            }
+        }
+        JSONObject adNew = new JSONObject();
+        JSONObject ad = new JSONObject();
+        for (AdConfigTypeVO adType : AdConfigTypeVO.values()) {
+            ADConfig adConfig = getAdShowType(adType.getDbKey(), acceptData.getChannel(), acceptData.getVersion(), map);
+            // 鍒ゆ柇骞垮憡鏄惁鏍规嵁鍦板煙灞忚斀
+            if (ipInfo != null) {
+                ThirdAdType thirdAdType = AdAreaUtil.getAdType(ipInfo.getProvince(), ipInfo.getCity(), adType, areaConfigList);
+                if (thirdAdType != null) {
+                    if (thirdAdType == ThirdAdType.none) {
+                        // 涓嶅睍绀哄箍鍛�
+                        adConfig = null;
+                    } else if (adConfig != null) {
+                        // 鎸囧畾骞垮憡绫诲瀷
+                        adConfig.setType(thirdAdType.name());
                     }
                 }
             }
+            ad.put(adType.getVoKey(), adConfig == null ? "" : adConfig.getType());
+            adNew.put(adType.getVoKey(), gson.toJson(adConfig));
         }
-        return false;
+
+        //骞垮憡ID
+        if (!StringUtil.isNullOrEmpty(map.get("gdt_app_id"))) {
+            adNew.put("gdtAppId", map.get("gdt_app_id"));
+        }
+
+        if (!StringUtil.isNullOrEmpty(map.get("csj_app_id"))) {
+            adNew.put("csjAppId", map.get("csj_app_id"));
+        }
+
+        data.put("ad", ad);
+        data.put("adNew", adNew);
     }
 
+
     public void getConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
+        LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createAppSplash(new BaseLog(acceptData, "")));
         DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
-        Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
+        Map<String, String> map = configService.getConfigAsMap(acceptData.getChildDetailSystem(), acceptData.getVersion());
         JSONObject data = new JSONObject();
-        JSONObject ad = new JSONObject();
-        JSONObject adNew = new JSONObject();
+
 
         String ip = IPUtil.getRemotIP(request);
         //浼氬憳閾炬帴
         String vipLink = map.get("vip_link");
         data.put("vipLink", vipLink);
 
-        ADConfig splashConfig = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
+        //鏄惁涓哄唴瀹归槄璇荤敤鎴�
+        boolean isDPUser = false;
+        try {
+            isDPUser = userDPContentWatchStatisticService.isDPUser(acceptData);
+        } catch (Exception e) {
 
-
-        //寮�灞忕殑鍦板尯灞忚斀瑙勫垯
-        String shieldInfo = map.get("shield_province");
-        boolean hiddenSplash = false;
-        if (!StringUtil.isNullOrEmpty(shieldInfo)) {
-            JSONObject json = JSONObject.fromObject(shieldInfo);
-            //鑾峰彇娓犻亾闇�瑕佸睆钄界殑鍩庡競
-            String province = json.optString(acceptData.getChannel().toLowerCase());
-            if (splashConfig != null && !StringUtil.isNullOrEmpty(province)) {
-
-                IPUtil.IPInfo ipInfo = null;
-                try {
-                    ipInfo = ipManager.getIPInfo(ip);
-                } catch (Exception e) {
-                    e.printStackTrace();
-                }
-                if (ipInfo != null && ipInfo.getProvince().contains(province)) {//灞忚斀IP
-                    hiddenSplash = true;
-                    LogHelper.print("鍩庡競灞忚斀:" + province);
-                }
-            }
         }
-        //骞垮憡鍏ㄩ儴灞忚斀鍖哄煙
-        String shieldAdLocationInfo = map.get("shield_ad_ip_location");
-        boolean hiddenAll = shieldAllAd(acceptData.getChannel(), acceptData.getVersion(), shieldAdLocationInfo, ip);
+        // 鍔犺浇骞垮憡閰嶇疆
+        loadAdConfig(acceptData, map, ip, isDPUser, data);
 
+        //PPTV鍏嶅箍鍛婃潈鐩婃椂闀�,鏆傛椂璁剧疆涓�3灏忔椂
+        data.put("pptvNoAdRewardHour", 3);
+        //璁剧疆缃戦〉鍔犻�熷煙鍚�
+        data.put("webSpeedUpHost", map.get("web_speed_up_host"));
+        //鎴戠殑椤甸潰banner
+        data.put("minePageBanner", map.get("mine_page_banner"));
+        //鎾斁椤靛璺冲崗璁櫧鍚嶅崟
+        data.put("jumpAppProtocolPrefix", map.get("player_out_jump_protocol_prefix"));
+        //鑾峰彇璐拱璁板綍閾炬帴
+        data.put("buyRecordUrl", systemConfigService.getConfigValueByKeyCache("buyRecordUrl"));
 
-        if (hiddenSplash)
-            splashConfig = null;
+        //鑱旂郴鎴戜滑
+        data.put("contactUsLink", map.get("contact_us_link"));
+        //娉ㄩ攢
+        data.put("unRegisterLink", map.get("unregister_link"));
 
-        String splash = "";
-        if (splashConfig != null)
-            splash = splashConfig.getType();
+        //鍏充簬鎴戜滑閾炬帴
+        data.put("aboutUsLink", map.get("about_us_link"));
+        //鍙嶉閾炬帴
+        data.put("feedBackLink", map.get("feed_back_link"));
+        //甯姪閾炬帴
+        data.put("helpLink", map.get("help_link"));
+        //搴旂敤閾炬帴
+        data.put("appLink", map.get("app_link"));
 
-        Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
+        //鏄惁姝e湪涓婄嚎
 
-        if (hiddenAll)
-            splashConfig = null;
-        //寮�灞�
-        ad.put("splash", splash);
-        adNew.put("splash", gson.toJson(splashConfig));
+        boolean onLine = false;
+        try {
+            onLine = appManager.isOnline(acceptData.getDetailSystem().getId(), acceptData.getVersion(), acceptData.getChannel());
+        } catch (Exception e) {
+        }
+        data.put("onLining", onLine);
+        String aidao = map.get("ai_dao_mode");
+        if ("1".equalsIgnoreCase((aidao + "").trim())) {
+            data.put("aiDaoMode", true);
+        } else {
+            data.put("aiDaoMode", false);
+        }
 
-
-        ADConfig adConfig = null;
-        //瑙嗛鍓嶈创
-        adConfig = getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map);
-        if (hiddenAll)
-            adConfig = null;
-        ad.put("videoPlayPre", adConfig == null ? "" : adConfig.getType());
-        adNew.put("videoPlayPre", gson.toJson(adConfig));
-        //APP閫�鍑�
-        adConfig = getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map);
-        if (hiddenAll)
-            adConfig = null;
-        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);
-        if (hiddenAll)
-            adConfig = null;
-        ad.put("videoDetailFullVideo", adConfig == null ? "" : adConfig.getType());
-        adNew.put("videoDetailFullVideo", gson.toJson(adConfig));
-        //鎼滅储椤靛箍鍛婃帶鍒�
-        adConfig = getAdShowType("ad_video_search", acceptData.getChannel(), acceptData.getVersion(), map);
-        if (hiddenAll)
-            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()));
     }
 
@@ -216,7 +245,7 @@
      * @param out
      */
     public void getHomeConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
-        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
+        LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createAppMainPage(new BaseLog(acceptData, "")));
         List<FloatAD> adList = floatADService.listShowAD(1, 1);
         Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
         JSONObject data = new JSONObject();
@@ -258,6 +287,8 @@
         public void setPid(String pid) {
             this.pid = pid;
         }
+
+
     }
 
 }

--
Gitblit v1.8.0