From 19533a17aa55fafc70d0a385928e785cb50e1ebc Mon Sep 17 00:00:00 2001 From: admin <2780501319@qq.com> Date: 星期五, 30 七月 2021 02:05:14 +0800 Subject: [PATCH] 爱奇艺视频更新 --- src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java | 46 +++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 45 insertions(+), 1 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 6b5a106..df8131e 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java @@ -2,7 +2,9 @@ import java.io.PrintWriter; import java.lang.reflect.Type; +import java.math.BigDecimal; import java.util.HashMap; +import java.util.Iterator; import java.util.List; import java.util.Map; @@ -19,6 +21,7 @@ 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.service.inter.system.SystemConfigService; import com.yeshi.buwan.service.manager.IPManager; import com.yeshi.buwan.util.IPUtil; import com.yeshi.buwan.util.StringUtil; @@ -51,6 +54,9 @@ @Resource private IPManager ipManager; + @Resource + private SystemConfigService systemConfigService; + public ADConfig getAdShowType(String key, String channel, int version, Map<String, String> map) { String splash = map.get(key); @@ -63,10 +69,35 @@ // 榛樿涓哄簲鐢ㄥ疂 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; } @@ -222,6 +253,12 @@ adConfig = null; adNew.put("splashHotStart", gson.toJson(adConfig)); + //鍏朵粬骞垮憡 + adConfig = getAdShowType("ad_other", acceptData.getChannel(), acceptData.getVersion(), map); + if (hiddenAll) + adConfig = null; + adNew.put("other", gson.toJson(adConfig)); + data.put("ad", ad); data.put("adNew", adNew); @@ -229,7 +266,12 @@ 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")); out.print(JsonUtil.loadTrueJson(data.toString())); } @@ -285,6 +327,8 @@ public void setPid(String pid) { this.pid = pid; } + + } } -- Gitblit v1.8.0