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