From f13ed98e1de0ec7b85ed179212cc095f63480eed Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期四, 25 三月 2021 18:18:20 +0800 Subject: [PATCH] 全网搜优酷兼容 --- src/main/java/com/yeshi/buwan/controller/parser/UserParser.java | 289 ++++++++++++++++++++++++++++++++++++++------------------- 1 files changed, 193 insertions(+), 96 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 7710f05..9bcbf7c 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -2,22 +2,35 @@ 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.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.manager.SolrAlbumDataManager; +import com.yeshi.buwan.service.inter.juhe.InternetSearchVideoService; +import com.yeshi.buwan.service.manager.SolrAlbumVideoDataManager; 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.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; @@ -29,10 +42,11 @@ @Controller public class UserParser { + @Resource private SystemService systemService; @Resource - private ConfigService configService; + private DetailSystemConfigService configService; @Resource private UserService userService; @Resource @@ -52,7 +66,7 @@ @Resource private VideoInfoService videoInfoService; @Resource - private SolrAlbumDataManager solrDataManager; + private SolrAlbumVideoDataManager solrDataManager; @Resource private ConfigParser configParser; @@ -198,7 +212,7 @@ private List<VideoDetailInfo> createSearchVideoDetailsVO(VideoInfo video) { List<VideoDetailInfo> detailList = new ArrayList<>(); if (video.getVideoType() != null && (Integer.parseInt(video.getVideoType().getId() + "") == VideoCategoryConstant.CATEGORY_DIANSHIJU || Integer.parseInt(video.getVideoType().getId() + "") == VideoCategoryConstant.CATEGORY_DONGMAN)) { - if (video.getVideocount() <= 5) { + if (video.getVideocount() != null && video.getVideocount() <= 5) { for (int i = 0; i < video.getVideocount(); i++) { VideoDetailInfo detail = new VideoDetailInfo(); detail.setTag((i + 1) + ""); @@ -333,6 +347,8 @@ // 鎼滅储 public void searchNew(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { + + //type: 0-鍏ㄩ儴 1- String key = request.getParameter("Key"); String type = request.getParameter("Type"); @@ -348,116 +364,159 @@ return; } + LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createSearch(new BaseLog(acceptData, ""), key, type)); + int pageIndex = StringUtil.getPage(page); if (pageIndex <= 0) { pageIndex = 1; } - DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); - UserInfo user1 = userService.getUserInfo(acceptData.getUid()); - if (Utils.isTest(request, user1, detailSystem.getId())) { - detailSystem = systemService.getDetailSystemById(40 + ""); - JSONObject object = new JSONObject(); - object.put("count", 0); - JSONArray array = new JSONArray(); - object.put("data", array); - out.print(JsonUtil.loadTrueJson(object.toString())); - } else { - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion()); - String cacheMD5 = "0"; - if (resourceList != null && resourceList.size() > 0) - for (Long l : resourceList) - cacheMD5 += "#" + l; - cacheMD5 = StringUtil.Md5(cacheMD5); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion()); - VideoListResultVO videoListResultVO = searchService.searchNew(detailSystem.getId(), request.getRemoteAddr(), - acceptData.getUid(), key, pageIndex, Integer.parseInt(type), - acceptData.getSystem(), resourceList, cacheMD5); - //缁勭粐鏁版嵁 - for (VideoInfo video : videoListResultVO.getVideoList()) { - //濡傛灉鏄鐗囷紝涓斾负5澶у垎绫� 灏遍噰鐢ㄧ珫鏉″睍绀� - if (video.getShowType() == 1) { - video.setVideoDetailList(createSearchVideoDetailsVO(video)); - } - } - cacheMD5 = "0"; - if (videoListResultVO.getVideoList() != null) { - for (VideoInfo info : videoListResultVO.getVideoList()) { - cacheMD5 += info.getId() + "#"; - } - } - List<VideoInfo> list = banQuanService.getBanQuanVideo(videoListResultVO.getVideoList(), detailSystem.getId(), cacheMD5); - JSONObject object = new JSONObject(); - object.put("count", Constant.isUpdate ? 19 + "" : videoListResultVO.getCount()); - JSONArray array = new JSONArray(); - for (int i = 0; i < list.size(); i++) { - if (JuheVideoUtil.isNeedDelete((VideoInfo) list.get(i), detailSystem.getId())) { - list.remove(i); - i--; - } - } -// -// List<String> keyList = banQuanService.getBanQuanKeyListAll(Integer.parseInt(detailSystem.getId())); -// for (int i = 0; i < list.size(); i++) { -// -// boolean delete = false; -// for (int j = 0; j < keyList.size(); j++) { -// if (list.get(i).getName().contains(keyList.get(j))) { -// delete = true; -// break; -// } -// } -// if (delete) { -// list.remove(i); -// i--; -// } -// -// } + String cacheMD5 = "0"; + if (resourceList != null && resourceList.size() > 0) + for (Long l : resourceList) + cacheMD5 += "#" + l; + cacheMD5 = StringUtil.Md5(cacheMD5); - 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()); - } - for (Iterator<Long> its = set.iterator(); its.hasNext(); ) { - Long typeId = its.next(); - String typeName = VideoConstant.getMainCategoryName(typeId); - if (!StringUtil.isNullOrEmpty(typeName)) { - vt = new VideoType(); - vt.setId(typeId); - vt.setName(typeName); - typeList.add(vt); - } - } - JSONArray array1 = new JSONArray(); - for (VideoType vt1 : typeList) - array1.add(StringUtil.outPutResultJson(vt1)); - object.put("typeList", array1); + VideoListResultVO videoListResultVO = searchService.searchNew(acceptData.getDetailSystem().getId(), request.getRemoteAddr(), + acceptData.getUid(), key, pageIndex, Integer.parseInt(type), + acceptData.getSystem(), resourceList, cacheMD5); + //缁勭粐鏁版嵁 + for (VideoInfo video : videoListResultVO.getVideoList()) { + //濡傛灉鏄鐗囷紝涓斾负5澶у垎绫� 灏遍噰鐢ㄧ珫鏉″睍绀� + if (video.getShowType() == 1) { + video.setVideoDetailList(createSearchVideoDetailsVO(video)); } - - out.print(JsonUtil.loadTrueJson(object.toString())); } + cacheMD5 = "0"; + if (videoListResultVO.getVideoList() != null) { + for (VideoInfo info : videoListResultVO.getVideoList()) { + cacheMD5 += info.getId() + "#"; + } + } + List<VideoInfo> list = banQuanService.getBanQuanVideo(videoListResultVO.getVideoList(), acceptData.getDetailSystem().getId(), cacheMD5); + + JSONObject object = new JSONObject(); + object.put("count", Constant.isUpdate ? 19 + "" : videoListResultVO.getCount()); + JSONArray array = new JSONArray(); + for (int i = 0; i < list.size(); i++) { + if (JuheVideoUtil.isNeedDelete((VideoInfo) list.get(i), acceptData.getDetailSystem().getId())) { + list.remove(i); + i--; + } + } + + 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()); + } + + for (Iterator<Long> its = set.iterator(); its.hasNext(); ) { + Long typeId = its.next(); + String typeName = VideoConstant.getMainCategoryName(typeId); + if (!StringUtil.isNullOrEmpty(typeName)) { + vt = new VideoType(); + vt.setId(typeId); + vt.setName(typeName); + typeList.add(vt); + } + } + + vt = new VideoType(); + vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION); + vt.setName("楂樻竻"); + typeList.add(vt); + + + JSONArray array1 = new JSONArray(); + for (VideoType vt1 : typeList) + array1.add(StringUtil.outPutResultJson(vt1)); + object.put("typeList", array1); + } + + 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()); @@ -630,6 +689,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())); + } + + } + /** * 鐩稿叧瑙嗛 * @@ -643,6 +735,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