From 745320cbb4edfa4fbc8f0f95483a4ee7893d5769 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期四, 22 四月 2021 20:18:08 +0800 Subject: [PATCH] 3.9.2完善 --- src/main/java/com/yeshi/buwan/controller/parser/UserParser.java | 270 +++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 258 insertions(+), 12 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 bde84a6..da328aa 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -1,36 +1,56 @@ 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; +import com.yeshi.buwan.dto.search.SolrResultDTO; +import com.yeshi.buwan.dto.search.SolrVideoSearchFilter; import com.yeshi.buwan.dto.user.LoginInfoDto; import com.yeshi.buwan.exception.user.LoginUserException; import com.yeshi.buwan.exception.user.RegisterUserException; 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.*; import com.yeshi.buwan.util.JuHe.VideoResourceUtil; import com.yeshi.buwan.util.annotation.RequireUid; import com.yeshi.buwan.util.email.MailSenderUtil; +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; import com.yeshi.buwan.vo.video.VideoListResultVO; import net.sf.json.JSONArray; 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 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 public class UserParser { + @Resource private SystemService systemService; @Resource @@ -56,7 +76,11 @@ @Resource private SolrAlbumVideoDataManager solrDataManager; @Resource + 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()); @@ -185,6 +209,13 @@ } } } + if (list == null || list.size() < 3) { + List<String> list1 = solrInternetSearchVideoDataManager.getSuggestKeyList(key); + if (list1 != null) { + list.addAll(list1); + } + } + JSONObject object = new JSONObject(); object.put("count", list.size() + ""); JSONArray array = new JSONArray(); @@ -335,6 +366,8 @@ // 鎼滅储 public void searchNew(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + + //type: 0-鍏ㄩ儴 1- String key = request.getParameter("Key"); String type = request.getParameter("Type"); @@ -349,6 +382,8 @@ out.print(JsonUtil.loadFalseJson("璇蜂笂浼燭ype")); return; } + + LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createSearch(new BaseLog(acceptData, ""), key, type)); int pageIndex = StringUtil.getPage(page); if (pageIndex <= 0) { @@ -393,26 +428,49 @@ } } - 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(); vt.setId(0); vt.setName("鍏ㄩ儴"); typeList.add(vt); - Set<Long> set = new HashSet<>(); - for (VideoInfo videoInfo : list) { - if (videoInfo.getShowType() == 1 && videoInfo.getVideoType() != null) - set.add(videoInfo.getVideoType().getId()); + List<Long> set = new ArrayList<>(); + //灏嗚棰戝唴瀹瑰垎绫诲苟鎺掑簭 + Map<Long, List<VideoInfo>> videoMap = new HashMap<>(); + for (int i = 0; i < list.size(); i++) { + VideoInfo videoInfo = list.get(i); + if (videoInfo.getShowType() == 1 && videoInfo.getVideoType() != null) { + if (videoMap.get(videoInfo.getVideoType().getId()) == null) + videoMap.put(videoInfo.getVideoType().getId(), new ArrayList<>()); + videoMap.get(videoInfo.getVideoType().getId()).add(videoInfo); + if (!set.contains(videoInfo.getVideoType().getId())) + set.add(videoInfo.getVideoType().getId()); + + if (VersionUtil.isGraterThan390(acceptData.getPlatform(), acceptData.getVersion()) && (StringUtil.isNullOrEmpty(type) || type.equalsIgnoreCase("0"))) { + list.remove(i); + i--; + } + } } - for (Iterator<Long> its = set.iterator(); its.hasNext(); ) { - Long typeId = its.next(); + //閲嶆柊缁勭粐鏁版嵁 + if (VersionUtil.isGraterThan390(acceptData.getPlatform(), acceptData.getVersion()) && (StringUtil.isNullOrEmpty(type) || type.equalsIgnoreCase("0"))) { + List<VideoInfo> albumVideoList = new ArrayList<>(); + for (int i = 0; i < set.size(); i++) { + Long typeId = set.get(i); + String typeName = VideoConstant.getMainCategoryName(typeId); + if (!StringUtil.isNullOrEmpty(typeName)) { + videoMap.get(typeId).get(0).setAlbumMoreInfo(new VideoInfo.VideoAlbumMoreInfo(typeName, i + 1)); + albumVideoList.addAll(videoMap.get(typeId)); + } + } + list.addAll(0, albumVideoList); + } + + + for (int i = 0; i < set.size(); i++) { + Long typeId = set.get(i); String typeName = VideoConstant.getMainCategoryName(typeId); if (!StringUtil.isNullOrEmpty(typeName)) { vt = new VideoType(); @@ -421,6 +479,7 @@ typeList.add(vt); } } + vt = new VideoType(); vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION); @@ -434,15 +493,80 @@ 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())); } + @Resource + private InternetSearchVideoService internetSearchVideoService; + + private void guessLikeForInternetSearch(AcceptData acceptData, String videoId, PrintWriter out) { + InternetSearchVideo internetSearchVideo = internetSearchVideoService.selectByPrimaryKey(videoId); + if (internetSearchVideo != null) { + int rootType = internetSearchVideo.getRootType(); + SolrVideoSearchFilter filter = new SolrVideoSearchFilter(); + filter.setVideoType(rootType); + filter.setResourceIds(new String[]{PPTVUtil.RESOURCE_ID + ""}); + filter.setSortKey("watchcount"); + SolrResultDTO dto = solrDataManager.find(filter, 1, 20); + List<SolrAlbumVideo> solrAlbumVideoList = new ArrayList<>(); + solrAlbumVideoList.addAll(dto.getVideoList()); + List<VideoInfo> list = new ArrayList<>(); + for (int i = 0; i < 4; i++) { + if (solrAlbumVideoList.size() > 0) { + int p = (int) (Math.random() * solrAlbumVideoList.size()); + SolrAlbumVideo solrAlbumVideo = solrAlbumVideoList.get(p); + list.add(VideoInfoFactory.create(solrAlbumVideo)); + solrAlbumVideoList.remove(p); + } + } + + if (list.size() < 4) { + filter.setResourceIds(null); + dto = solrDataManager.find(filter, 1, 20); + solrAlbumVideoList.clear(); + solrAlbumVideoList.addAll(dto.getVideoList()); + for (int i = list.size(); i < 4; i++) { + if (solrAlbumVideoList.size() > 0) { + int p = (int) (Math.random() * solrAlbumVideoList.size()); + SolrAlbumVideo solrAlbumVideo = solrAlbumVideoList.get(p); + list.add(VideoInfoFactory.create(solrAlbumVideo)); + solrAlbumVideoList.remove(p); + } + } + } + + + 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))); + } + + object.put("data", array); + out.print(JsonUtil.loadTrueJson(object.toString())); + } + + } + // 鐚滀綘鍠滄 public void guessLike(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { String videoId = request.getParameter("VideoId"); + if (!NumberUtil.isNumeric(videoId)) { + guessLikeForInternetSearch(acceptData, videoId, out); + return; + } DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); @@ -497,6 +621,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())); } // 鑾峰彇鐢ㄦ埛淇℃伅 @@ -615,6 +823,39 @@ } + + private void getRelativeVideosForInternetSearch(AcceptData acceptData, String videoId, PrintWriter out) { + InternetSearchVideo internetSearchVideo = internetSearchVideoService.selectByPrimaryKey(videoId); + if (internetSearchVideo != null) { + SolrVideoSearchFilter filter = new SolrVideoSearchFilter(); + filter.setKey(internetSearchVideo.getName()); + filter.setFuzzy(true); + SolrResultDTO dto = solrDataManager.find(filter, 1, 20); + List<SolrAlbumVideo> solrAlbumVideoList = new ArrayList<>(); + solrAlbumVideoList.addAll(dto.getVideoList()); + List<VideoInfo> list = new ArrayList<>(); + for (int i = 0; i < 4; i++) { + if (i < solrAlbumVideoList.size()) { + SolrAlbumVideo solrAlbumVideo = solrAlbumVideoList.get(i); + list.add(VideoInfoFactory.create(solrAlbumVideo)); + } + } + + + 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))); + } + + object.put("data", array); + out.print(JsonUtil.loadTrueJson(object.toString())); + } + + } + /** * 鐩稿叧瑙嗛 * @@ -628,6 +869,11 @@ return; } + if (!NumberUtil.isNumeric(videoId)) { + getRelativeVideosForInternetSearch(acceptData, videoId, out); + return; + } + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); -- Gitblit v1.8.0