From f788607ff771a47bc60d6a86e00b3433c40f3d2c Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期五, 24 九月 2021 15:22:03 +0800 Subject: [PATCH] 接入视频直播 --- src/main/java/com/yeshi/buwan/controller/parser/UserParser.java | 163 ++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 139 insertions(+), 24 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 84bff4d..9598bf3 100644 --- a/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java +++ b/src/main/java/com/yeshi/buwan/controller/parser/UserParser.java @@ -5,32 +5,36 @@ import com.yeshi.buwan.domain.*; import com.yeshi.buwan.domain.Collection; import com.yeshi.buwan.domain.solr.SolrAlbumVideo; +import com.yeshi.buwan.domain.solr.SolrShortVideo; 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.SolrShortVideoSearchFilter; 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.videos.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.service.manager.search.SolrAlbumVideoDataManager; +import com.yeshi.buwan.service.manager.search.SolrInternetSearchVideoDataManager; +import com.yeshi.buwan.service.manager.search.SolrShortVideoDataManager; 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.factory.vo.UserInfoVOFactory; 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.util.video.VideoUtil; import com.yeshi.buwan.vo.AcceptData; import com.yeshi.buwan.vo.video.VideoListResultVO; import net.sf.json.JSONArray; @@ -38,18 +42,21 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Controller; +import redis.clients.jedis.Jedis; 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 { + + Logger searchKeyLogger = LoggerFactory.getLogger("searchKey"); + @Resource private SystemService systemService; @@ -77,10 +84,17 @@ private SolrAlbumVideoDataManager solrDataManager; @Resource private SolrInternetSearchVideoDataManager solrInternetSearchVideoDataManager; + + @Resource + private SolrShortVideoDataManager solrShortVideoDataManager; + @Resource private ConfigParser configParser; @Resource private SystemConfigService systemConfigService; + + @Resource + private RedisManager redisManager; public void getUid(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName()); @@ -91,7 +105,7 @@ out.print(JsonUtil.loadFalseJson("鑾峰彇uid澶辫触")); return; } else { - Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion()); + Map<String, String> map = configService.getConfigAsMap(acceptData.getChildDetailSystem(), acceptData.getVersion()); ShareContent share = shareService.getShareContent(detailSystem.getId()); JSONObject object = new JSONObject(); object.put("Uid", uid); @@ -316,7 +330,7 @@ object.put("data", array); out.print(JsonUtil.loadTrueJson(object.toString())); } else { - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion(),acceptData.getChannel()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(detailSystem, acceptData.getVersion(), acceptData.getChannel()); String cacheMD5 = "0"; if (resourceList != null && resourceList.size() > 0) for (Long l : resourceList) @@ -403,6 +417,30 @@ return; } + final String id = StringUtil.Md5(String.format("%s#%s#%s#%s", acceptData.getDetailSystem().getId(), acceptData.getDevice(), key, type)); + ThreadUtil.run(new Runnable() { + @Override + public void run() { + String redisKey = "search-" + id; + Jedis jedis = redisManager.getJedis(); + try { + //閲嶅璇锋眰杩囨护 + if (jedis.setnx(redisKey, "1") <= 0) { + return; + } + jedis.expire(redisKey, 120); + JSONObject searchData = new JSONObject(); + searchData.put("key", key); + searchData.put("type", type); + searchData.put("detailSystemId", acceptData.getDetailSystem().getId()); + searchData.put("device", acceptData.getDevice()); + searchData.put("createTime", System.currentTimeMillis()); + searchKeyLogger.info(new Gson().toJson(searchData)); + } finally { + jedis.close(); + } + } + }); LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createSearch(new BaseLog(acceptData, ""), key, type)); int pageIndex = StringUtil.getPage(page); @@ -410,7 +448,7 @@ pageIndex = 1; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); + List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(), acceptData.getChannel()); String cacheMD5 = "0"; @@ -500,11 +538,13 @@ } } - - vt = new VideoType(); - vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION); - vt.setName("楂樻竻"); - typeList.add(vt); + //闊╁墽涓嶈繑鍥為珮娓� + if (!acceptData.getDetailSystem().getId().equalsIgnoreCase("48")) { + vt = new VideoType(); + vt.setId(Constant.SEARCH_RESULT_TYPE_HIGH_DEFINITION); + vt.setName("楂樻竻"); + typeList.add(vt); + } JSONArray array1 = new JSONArray(); @@ -534,7 +574,7 @@ int rootType = internetSearchVideo.getRootType(); SolrVideoSearchFilter filter = new SolrVideoSearchFilter(); filter.setVideoType(rootType); - filter.setResourceIds(new String[]{PPTVUtil.RESOURCE_ID + ""}); + filter.setResourceIds(Arrays.asList(new String[]{PPTVUtil.RESOURCE_ID + ""})); filter.setSortKey("watchcount"); SolrResultDTO dto = solrDataManager.find(filter, 1, 20); List<SolrAlbumVideo> solrAlbumVideoList = new ArrayList<>(); @@ -579,18 +619,53 @@ } + + private void guessLikeForShortVideo(AcceptData acceptData, String videoId, PrintWriter out) { + SolrShortVideo solrShortVideo = solrShortVideoDataManager.findOne(videoId); + SolrShortVideoSearchFilter filter = new SolrShortVideoSearchFilter(); + filter.setRootVideoType(solrShortVideo.getRootVideoType()); + if (solrShortVideo.getArea() != null) { + filter.setAreas(Arrays.asList(solrShortVideo.getArea().split(","))); + } + + SolrResultDTO dto = solrShortVideoDataManager.find(filter, 1, 10); + + + JSONObject object = new JSONObject(); + object.put("count", dto.getVideoList().size() + ""); + JSONArray array = new JSONArray(); + + for (int i = 0; i < dto.getVideoList().size(); i++) { + SolrShortVideo temp = (SolrShortVideo) dto.getVideoList().get(i); + if (temp.getId().equalsIgnoreCase(videoId)) + continue; + array.add(StringUtil.outPutResultJson(VideoInfoFactory.create(temp))); + } + if (array.size() % 2 != 0) { + array.remove(array.size() - 1); + } + + 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; + int fromtype = VideoUtil.getVideoFromType(videoId); + switch (fromtype) { + case HomeVideo.FROM_TYPE_INTERNET: + guessLikeForInternetSearch(acceptData, videoId, out); + return; + case HomeVideo.FROM_TYPE_SHORT: + guessLikeForShortVideo(acceptData, videoId, out); + return; } DetailSystem ds = systemService.getDetailSystemByPackage(acceptData.getPackageName()); - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); + 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, @@ -646,7 +721,7 @@ //鏂扮増鐑棬鎼滅储 public void getHotSearchNew(AcceptData acceptData, HttpServletRequest request, PrintWriter out) { - DetailSystemConfig config = configService.getConfigByKey("hot_search", acceptData.getDetailSystem(), acceptData.getVersion()); + DetailSystemConfig config = configService.getConfigByKey("hot_search", acceptData.getDetailSystem(), acceptData.getVersion()); if (config == null) { out.print(JsonUtil.loadFalseJson("鏃犲唴瀹�")); return; @@ -876,6 +951,35 @@ } + + private void getRelativeVideosForShortVideo(AcceptData acceptData, String videoId, PrintWriter out) { + SolrShortVideo solrShortVideo = solrShortVideoDataManager.findOne(videoId); + SolrShortVideoSearchFilter filter = new SolrShortVideoSearchFilter(); + filter.setKey(solrShortVideo.getName()); + filter.setFuzzy(true); + + SolrResultDTO dto = solrShortVideoDataManager.find(filter, 1, 10); + + + JSONObject object = new JSONObject(); + object.put("count", dto.getVideoList().size() + ""); + JSONArray array = new JSONArray(); + + for (int i = 0; i < dto.getVideoList().size(); i++) { + SolrShortVideo temp = (SolrShortVideo) dto.getVideoList().get(i); + if (temp.getId().equalsIgnoreCase(videoId)) + continue; + array.add(StringUtil.outPutResultJson(VideoInfoFactory.create(temp))); + } + if (array.size() % 2 != 0) { + array.remove(array.size() - 1); + } + + object.put("data", array); + out.print(JsonUtil.loadTrueJson(object.toString())); + } + + /** * 鐩稿叧瑙嗛 * @@ -889,12 +993,17 @@ return; } - if (!NumberUtil.isNumeric(videoId)) { - getRelativeVideosForInternetSearch(acceptData, videoId, out); - return; + int fromtype = VideoUtil.getVideoFromType(videoId); + switch (fromtype) { + case HomeVideo.FROM_TYPE_INTERNET: + getRelativeVideosForInternetSearch(acceptData, videoId, out); + return; + case HomeVideo.FROM_TYPE_SHORT: + getRelativeVideosForShortVideo(acceptData, videoId, out); + return; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); + 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, @@ -933,7 +1042,7 @@ return; } - List<Long> resourceList = videoResouceUtil.getAvailableResourceIds(acceptData.getDetailSystem(), acceptData.getVersion(),acceptData.getChannel()); + 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, @@ -1158,6 +1267,12 @@ // 娉ㄥ唽 --鐢ㄦ埛鍚�,鏄电О,瀵嗙爜 LoginUser user = userService.getLoginUser(loginUid); + if (user.getState() != null && user.getState() == LoginUser.STATE_UNREGISTER) { + out.print(JsonUtil.loadFalseJson("璐︽埛宸叉敞閿�")); + return; + } + //闅愯棌user涓殑email + user.setEmail(UserInfoVOFactory.getHiddenEmail(user.getEmail())); if (user.getPortrait() != null && !user.getPortrait().startsWith("http")) user.setPortrait("http://" + Constant.WEBSITE + "/BuWan" + user.getPortrait()); out.print(JsonUtil.loadTrueJson(StringUtil.outPutResultJson(user))); -- Gitblit v1.8.0