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/UserParser.java | 176 ++++++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 150 insertions(+), 26 deletions(-) diff --git a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java index 6ec01ea..84bff4d 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -1,9 +1,12 @@ package com.yeshi.buwan.controller.parser; +import com.google.gson.Gson; +import com.google.gson.reflect.TypeToken; import com.yeshi.buwan.domain.*; import com.yeshi.buwan.domain.Collection; import com.yeshi.buwan.domain.solr.SolrAlbumVideo; import com.yeshi.buwan.domain.system.DetailSystem; +import com.yeshi.buwan.domain.system.DetailSystemConfig; import com.yeshi.buwan.domain.user.LoginUser; import com.yeshi.buwan.domain.video.InternetSearchVideo; import com.yeshi.buwan.dto.log.BaseLog; @@ -15,6 +18,7 @@ import com.yeshi.buwan.pptv.PPTVUtil; import com.yeshi.buwan.service.imp.*; import com.yeshi.buwan.service.inter.juhe.InternetSearchVideoService; +import com.yeshi.buwan.service.inter.system.SystemConfigService; import com.yeshi.buwan.service.manager.SolrAlbumVideoDataManager; import com.yeshi.buwan.service.manager.SolrInternetSearchVideoDataManager; import com.yeshi.buwan.util.*; @@ -24,6 +28,7 @@ import com.yeshi.buwan.util.factory.VideoInfoFactory; import com.yeshi.buwan.util.log.LoggerUtil; import com.yeshi.buwan.util.log.UserActiveLogFactory; +import com.yeshi.buwan.util.rank.IqiyiRankUtil; import com.yeshi.buwan.util.video.VideoCategoryConstant; import com.yeshi.buwan.util.video.VideoConstant; import com.yeshi.buwan.vo.AcceptData; @@ -38,7 +43,9 @@ import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpSession; import java.io.File; +import java.io.IOException; import java.io.PrintWriter; +import java.lang.reflect.Type; import java.util.*; @Controller @@ -72,6 +79,8 @@ private SolrInternetSearchVideoDataManager solrInternetSearchVideoDataManager; @Resource private ConfigParser configParser; + @Resource + private SystemConfigService systemConfigService; public void getUid(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); @@ -92,7 +101,7 @@ object.put("ZiXun", map.get("zixun_url")); if (acceptData.getPlatform().equalsIgnoreCase("ios") && !"涓浗".equalsIgnoreCase(userInfo.getCountry()))// 姝e湪瀹℃牳鐨勭増鏈� object.put("CommentUrl", ""); - else + else if (share != null) object.put("CommentUrl", share.getShareUrl()); object.put("IOSSlotID", ""); @@ -158,12 +167,10 @@ // 骞垮憡绫诲瀷 object.put("adType", map.get("ad_type")); - int fullVideoVersion = Integer.parseInt(map.get("video_detail_full_video_version")); - String fullVideoVersionChannels = map.get("video_detail_full_video_version_channel"); - JSONObject json = JSONObject.fromObject(fullVideoVersionChannels); - if (json.optInt(acceptData.getChannel().toLowerCase(), 0) > 0) { - fullVideoVersion = json.optInt(acceptData.getChannel().toLowerCase(), 0); - } +// String fullVideoVersionChannels = map.get("video_detail_full_video_version_channel"); +// JSONObject json = JSONObject.fromObject(fullVideoVersionChannels); +// if (json.optInt(acceptData.getChannel().toLowerCase(), 0) > 0) { +// } ConfigParser.ADConfig adConfig = configParser.getAdShowType("ad_video_detail_full_video", acceptData.getChannel(), acceptData.getVersion(), map); @@ -200,19 +207,41 @@ } } } - if (list == null || list.size() < 3) { - List<String> list1 = solrInternetSearchVideoDataManager.getSuggestKeyList(key); - if (list1 != null) { - list.addAll(list1); - } + List<String> list1 = solrInternetSearchVideoDataManager.getSuggestKeyList(key); + if (list1 != null) { + list.addAll(list1); } + + Set<String> set = new HashSet<>(); + + if (list != null) { + for (String st : list) { + set.add(st); + } + list.clear(); + list.addAll(set); + } + + //鎸夊叧閿瘝鐨勫尮閰嶅害鎺掑簭 + Comparator<String> cm = new Comparator<String>() { + @Override + public int compare(String o1, String o2) { + float s1 = CompareStrSimUtil.getSimilarityRatio(o1, key, true); + float s2 = CompareStrSimUtil.getSimilarityRatio(o2, key, true); + return s2 > s1 ? 1 : -1; + } + }; + + Collections.sort(list, cm); + JSONObject object = new JSONObject(); object.put("count", list.size() + ""); JSONArray array = new JSONArray(); for (int i = 0; i < list.size(); i++) { - array.add(StringUtil.outPutResultJson(list.get(i))); + if (i < 10) + array.add(StringUtil.outPutResultJson(list.get(i))); } object.put("data", array); out.print(JsonUtil.loadTrueJson(object.toString())); @@ -287,7 +316,7 @@ object.put("data", array); out.print(JsonUtil.loadTrueJson(object.toString())); } else { - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion(),acceptData.getChannel()); String cacheMD5 = "0"; if (resourceList != null && resourceList.size() > 0) for (Long l : resourceList) @@ -381,7 +410,7 @@ pageIndex = 1; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); String cacheMD5 = "0"; @@ -419,12 +448,7 @@ } } - for (int i = 0; i < list.size(); i++) { - ((VideoInfo) list.get(i)) - .setPicture(VideoPictureUtil.getShowPicture((VideoInfo) list.get(i), acceptData.getPlatform(), acceptData.getVersion() + "")); - array.add(StringUtil.outPutResultJson(list.get(i))); - } - object.put("data", array); + if (pageIndex == 1) {//杩斿洖瀵艰埅鏍� List<VideoType> typeList = new ArrayList<>(); VideoType vt = new VideoType(); @@ -488,6 +512,13 @@ array1.add(StringUtil.outPutResultJson(vt1)); object.put("typeList", array1); } + + for (int i = 0; i < list.size(); i++) { + ((VideoInfo) list.get(i)) + .setPicture(VideoPictureUtil.getShowPicture((VideoInfo) list.get(i), acceptData.getPlatform(), acceptData.getVersion() + "")); + array.add(StringUtil.outPutResultJson(list.get(i))); + } + object.put("data", array); out.print(JsonUtil.loadTrueJson(object.toString())); @@ -559,7 +590,7 @@ DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); List<VideoInfo> list1 = StringUtil.isNullOrEmpty(videoId) ? recommendService.guessLikeList(ds.getId(), 4, resourceList, CacheUtil.getMD5Long(resourceList)) : recommendService.guessLikeList(ds.getId(), 4, videoId, resourceList, @@ -610,6 +641,90 @@ object.put("data", array); out.print(JsonUtil.loadTrueJson(object.toString())); + } + + + //鏂扮増鐑棬鎼滅储 + public void getHotSearchNew(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + DetailSystemConfig config = configService.getConfigByKey("hot_search", acceptData.getDetailSystem(), acceptData.getVersion()); + if (config == null) { + out.print(JsonUtil.loadFalseJson("鏃犲唴瀹�")); + return; + } + String value = config.getValue(); + Type type = new TypeToken<List<String>>() { + }.getType(); + + List<String> list = new Gson().fromJson(value, type); + + + JSONObject object = new JSONObject(); + object.put("count", list.size() + ""); + JSONArray array = new JSONArray(); + for (int i = 0; i < list.size(); i++) { + array.add(list.get(i)); + } + + object.put("data", array); + out.print(JsonUtil.loadTrueJson(object.toString())); + } + + + //鑾峰彇鎼滅储鎺掕姒� + public void getSearchRank(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { +// try { +// Map<String, List<String>> map = IqiyiRankUtil.getRank(10); +// } catch (IOException e) { +// e.printStackTrace(); +// } + + //鎼滅储鎺掕 + String value = systemConfigService.getConfigValueByKeyCache("searchRank"); + + Map<Integer, JSONObject> map = new TreeMap<>(); + if (!StringUtil.isNullOrEmpty(value)) { + JSONObject root = JSONObject.fromObject(value); + for (Iterator<String> its = root.keys(); its.hasNext(); ) { + String key = its.next(); + JSONArray array = root.optJSONArray(key); + JSONObject data = new JSONObject(); + switch (key) { + case "鐑悳": + data.put("鐑悳姒�", array); + map.put(0, data); + break; + case "鐢佃鍓�": + data.put("鐢佃鍓ф", array); + map.put(1, data); + break; + case "鐢靛奖": + data.put("鐢靛奖姒�", array); + map.put(2, data); + break; + case "缁艰壓": + data.put("缁艰壓姒�", array); + map.put(3, data); + break; + case "鍔ㄦ极": + data.put("鍔ㄦ极姒�", array); + map.put(4, data); + break; + } + } + } + + JSONObject data = new JSONObject(); + for (Iterator<Integer> its = map.keySet().iterator(); its.hasNext(); ) { + Integer key = its.next(); + JSONObject item = map.get(key); + String k = item.keys().next().toString(); + data.put(k, item.optJSONArray(k)); + } + + + JSONObject object = new JSONObject(); + object.put("data", data); + out.print(JsonUtil.loadTrueJson(object.toString())); } // 鑾峰彇鐢ㄦ埛淇℃伅 @@ -779,7 +894,7 @@ return; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); List<VideoInfo> list = recommendService.getRelativeVideoList(ds.getId(), 4, videoId, resourceList, @@ -818,7 +933,7 @@ return; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); List<VideoInfo> list1 = recommendService.peopleSee(ds.getId(), 4, videoId, resourceList, @@ -935,8 +1050,17 @@ // new Thread(new Runnable() { // public void run() { // for (int i = 0; i < 3; i++) { - boolean isS = MailSenderUtil.sendEmail(account, "ysyz17784739772@126.com", "weikou2014", "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code, - "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code); + DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); + String title = "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code; + String content = "甯冧父绀惧尯娉ㄥ唽楠岃瘉鐮�:" + code; + if (!detailSystem.getAppName().contains("甯冧父")) { + String name = detailSystem.getAppName(); + title = name + "楠岃瘉鐮�:" + code; + content = title; + } + + boolean isS = MailSenderUtil.sendEmail(account, "ysyz17784739772@126.com", "weikou2014", title, + content); // } // }).start(); -- Gitblit v1.8.0