From f537abe9f3646c739beaf15076246a2f71a347e9 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期四, 20 二月 2025 16:57:55 +0800 Subject: [PATCH] IOS广告增加区域屏蔽 --- src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java | 279 +++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 249 insertions(+), 30 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..2aed417 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java @@ -1,59 +1,269 @@ package com.yeshi.buwan.controller.parser; -import java.io.PrintWriter; -import java.util.Map; +import com.google.gson.Gson; +import com.google.gson.GsonBuilder; +import com.google.gson.annotations.Expose; +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.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 javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; - -import com.yeshi.buwan.domain.DetailSystem; -import com.yeshi.buwan.service.imp.SystemService; -import com.yeshi.buwan.vo.AcceptData; -import org.springframework.stereotype.Controller; - -import com.google.gson.Gson; -import com.yeshi.buwan.service.imp.ConfigService; -import com.yeshi.buwan.util.JsonUtil; - -import net.sf.json.JSONObject; +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 deviceGeoLogger = LoggerFactory.getLogger("deviceGeo"); + @Resource - private ConfigService configService; + private DetailSystemConfigService 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; + + @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); - ADConfig splashAD = null; - if (jsonObject.optJSONObject(channel) == null) { + if (jsonObject == null || jsonObject.isEmpty()) + return null; + ADConfig adConfig = null; + channel = channel.toLowerCase(); + if (jsonObject == null || 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(); + 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; + } + } + } - JSONObject data = new JSONObject(); + + return adConfig; + } + + + // 鑾峰彇骞垮憡閰嶇疆淇℃伅 + 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) { + + } + IPUtil.IPInfo ipInfo = null; + if (areaConfigList != null && areaConfigList.size() > 0) { +// if(!"appstore".equalsIgnoreCase(acceptData.getChannel())) { + try { + ipInfo = ipManager.getIPInfo(ip); + if (ipInfo != null) { + deviceGeoLogger.info("IP褰掑睘鍦帮細IP-{},鐗堟湰-{}, 娓犻亾-{}锛屽浗-{}, 鐪�-{}锛� 甯�-{}", ip, acceptData.getVersion(), acceptData.getChannel(), ipInfo.getCountry(), ipInfo.getProvince(), ipInfo.getCity()); + } + } catch (Exception e) { + e.printStackTrace(); + logger.error("IP鍦板潃浣嶇疆淇℃伅鑾峰彇澶辫触锛�" + ip); + } + } + JSONObject adNew = new JSONObject(); JSONObject ad = new JSONObject(); - ad.put("splash", splashAdType); + 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)); + } + + //骞垮憡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(acceptData.getChildDetailSystem(), acceptData.getVersion()); + JSONObject data = new JSONObject(); + + + String ip = IPUtil.getRemotIP(request); + //浼氬憳閾炬帴 + String vipLink = map.get("vip_link"); + data.put("vipLink", vipLink); + + //鏄惁涓哄唴瀹归槄璇荤敤鎴� + boolean isDPUser = false; + try { + isDPUser = userDPContentWatchStatisticService.isDPUser(acceptData); + } catch (Exception e) { + + } + // 鍔犺浇骞垮憡閰嶇疆 + 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")); + + //鑱旂郴鎴戜滑 + data.put("contactUsLink", map.get("contact_us_link")); + //娉ㄩ攢 + data.put("unRegisterLink", map.get("unregister_link")); + + //鍏充簬鎴戜滑閾炬帴 + 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")); + + //鏄惁姝e湪涓婄嚎 + + 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); + } + + out.print(JsonUtil.loadTrueJson(data.toString())); + } + + + /** + * 鑾峰彇棣栭〉閰嶇疆淇℃伅 + * + * @param acceptData + * @param request + * @param out + */ + public void getHomeConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + 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(); + 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 +281,15 @@ this.type = type; } + public String getPid() { + return pid; + } + + public void setPid(String pid) { + this.pid = pid; + } + + } } -- Gitblit v1.8.0