From f4548a3ee46afe45da4ee2a42dc169c575deee9f Mon Sep 17 00:00:00 2001 From: yujian <yujian@123.com> Date: 星期三, 31 七月 2019 11:57:36 +0800 Subject: [PATCH] 动态v2兼容 --- fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java | 165 +++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 124 insertions(+), 41 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java index 9ad6c4b..7a79777 100644 --- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java +++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java @@ -3,9 +3,9 @@ import java.io.PrintWriter; import java.math.BigDecimal; import java.util.ArrayList; +import java.util.Collections; import java.util.HashSet; import java.util.List; -import java.util.Map; import java.util.Set; import javax.annotation.Resource; @@ -19,6 +19,7 @@ import com.google.gson.Gson; import com.google.gson.GsonBuilder; +import com.yeshi.fanli.dto.dataoke.DaTaoKeGoodsResult; import com.yeshi.fanli.entity.accept.AcceptData; import com.yeshi.fanli.entity.bus.lable.QualityFactory; import com.yeshi.fanli.entity.bus.recommend.Honest; @@ -33,6 +34,8 @@ import com.yeshi.fanli.entity.taobao.TaoBaoSearchNav; import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult; import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig; +import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetail; +import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetailV2; import com.yeshi.fanli.service.inter.config.BusinessSystemService; import com.yeshi.fanli.service.inter.config.ConfigService; import com.yeshi.fanli.service.inter.config.SuperHotSearchService; @@ -41,14 +44,17 @@ import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService; import com.yeshi.fanli.service.inter.taobao.TaoBaoShopService; import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService; +import com.yeshi.fanli.service.inter.taobao.dataoke.DaTaoKeGoodsDetailService; import com.yeshi.fanli.service.inter.user.HistorySearchService; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.EhcacheUtil; import com.yeshi.fanli.util.StringUtil; import com.yeshi.fanli.util.ThreadUtil; import com.yeshi.fanli.util.cache.TaoBaoGoodsCacheUtil; +import com.yeshi.fanli.util.dataoke.DaTaoKeApiUtil; import com.yeshi.fanli.util.taobao.SearchFilterUtil; import com.yeshi.fanli.util.taobao.TaoBaoUtil; +import com.yeshi.fanli.vo.brand.TaoBaoShopVO; import net.sf.ehcache.Element; import net.sf.json.JSONArray; @@ -84,21 +90,29 @@ @Resource private TaoBaoGoodsCacheUtil taoBaoGoodsCacheUtil; - + @Resource private TaoBaoShopService taoBaoShopService; - + + @Resource + private DaTaoKeGoodsDetailService daTaoKeGoodsDetailService; @RequestMapping(value = "gethotsearch", method = RequestMethod.POST) - public void getHotSearch(AcceptData acceptData, PrintWriter out) { + public void getHotSearch(AcceptData acceptData, Integer goodsType, PrintWriter out) { BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), acceptData.getPackages()); if (system == null) { out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�")); return; } + + // 榛樿娣樺疂 + if (goodsType == null) { + goodsType = Constant.SOURCE_TYPE_TAOBAO; + } + List<SuperHotSearch> superHotSearchList = superHotSearchSerivce - .getSuperHotSearchBySystemIdCache(system.getId()); + .getSuperHotSearchBySystemIdCache(system.getId(), goodsType); if (superHotSearchList == null || superHotSearchList.size() == 0) { out.print(JsonUtil.loadFalseResult("娌℃湁鏁版嵁")); return; @@ -410,15 +424,20 @@ historySearchService.addHistorySearch(kw, bid); -// BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), -// acceptData.getPackages()); -// if (system == null) { -// out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�")); -// return; -// } + // BusinessSystem system = + // businessSystemService.getBusinessSystemCache(acceptData.getPlatform(), + // acceptData.getPackages()); + // if (system == null) { + // out.print(JsonUtil.loadFalseResult("绯荤粺涓嶅瓨鍦�")); + // return; + // } if (!StringUtil.isNullOrEmpty(kw) && (kw.startsWith("http://") || kw.startsWith("https://"))) { - out.print(JsonUtil.loadFalseResult("鏃犳硶鎼滅储閾炬帴")); + JSONObject data = new JSONObject(); + data.put("result", new JSONArray()); + data.put("count", 0); + data.put("nav", new JSONArray()); + out.print(JsonUtil.loadTrueResult(data)); return; } @@ -449,11 +468,14 @@ JSONObject data = null; if (!recommend) { + // 娣樺疂鎺ュ彛璇锋眰 data = searchGoods(kw, page, filter, order, startprice, endprice); } else { // 鎺ㄨ崘锛氱簿閫夊簱 - data = searchQualityGoods(kw, page, filter, order, startprice, endprice); + // data = searchQualityGoods(kw, page, filter, order, startprice, + // endprice); + data = searchDaTaoKeGoods(kw, page, filter, order, startprice, endprice); } // 鑾峰彇鎺ㄨ崘璇� @@ -463,6 +485,12 @@ listRecommendWords = TaoBaoUtil.getSuguestSearch(kw); if (listRecommendWords == null || listRecommendWords.size() == 0) { listRecommendWords = new ArrayList<String>(); + } + + List<TaoBaoShopVO> listShop =taoBaoShopService.getShopByKey(kw); + if (listShop != null && listShop.size() > 0 && listShop.get(0).getListGoods() != null + && listShop.get(0).getListGoods().size() > 2) { + data.put("shop", JsonUtil.getApiCommonGson().toJson(listShop.get(0))); } } @@ -602,38 +630,44 @@ sf.setParams(params); } + // 鎼滅储澶ф窐瀹� + List<DaTaoKeDetail> daTaoKeList = null; + if (page == 1) + daTaoKeList = daTaoKeGoodsDetailService.listByDtitle(kw); + TaoBaoSearchResult result = TaoBaoUtil.search(sf); if (result == null) { return null; } // 鎼滅储鏄惁鍦ㄨ惀閿�涓诲晢鍝佸簱 if (result != null && result.getTaoBaoGoodsBriefs() != null && result.getTaoBaoGoodsBriefs().size() > 0) { -// 鏆傛椂鏀惧純鏇存柊鍒拌惀閿�鍟嗗搧搴� -// String numIds = ""; -// for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) { -// numIds += goods.getAuctionId() + ","; -// } -// if (numIds.endsWith(",")) -// numIds = numIds.substring(0, numIds.length() - 1); -// try { -// List<TaoBaoGoodsBrief> goodsList = TaoKeApiUtil.getBatchGoodsInfos(numIds); -// Map<Long, Integer> map = new HashMap<>(); -// for (TaoBaoGoodsBrief g : goodsList) -// map.put(g.getAuctionId(), g.getMaterialLibType()); -// for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) -// goods.setMaterialLibType(map.get(goods.getAuctionId())); + // 鏆傛椂鏀惧純鏇存柊鍒拌惀閿�鍟嗗搧搴� + // String numIds = ""; + // for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) { + // numIds += goods.getAuctionId() + ","; + // } + // if (numIds.endsWith(",")) + // numIds = numIds.substring(0, numIds.length() - 1); + // try { + // List<TaoBaoGoodsBrief> goodsList = + // TaoKeApiUtil.getBatchGoodsInfos(numIds); + // Map<Long, Integer> map = new HashMap<>(); + // for (TaoBaoGoodsBrief g : goodsList) + // map.put(g.getAuctionId(), g.getMaterialLibType()); + // for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) + // goods.setMaterialLibType(map.get(goods.getAuctionId())); - ThreadUtil.run(new Runnable() { - @Override - public void run() { - // 鏇存柊鍒扮珐瀛� - for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) - taoBaoGoodsCacheUtil.saveCommonTaoBaoGoodsInfo(goods); - } - }); -// } catch (Exception e) { -// e.printStackTrace(); -// } + ThreadUtil.run(new Runnable() { + @Override + public void run() { + // 鏇存柊鍒扮珐瀛� + for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) + taoBaoGoodsCacheUtil.saveCommonTaoBaoGoodsInfo(goods); + } + }); + // } catch (Exception e) { + // e.printStackTrace(); + // } } @@ -645,14 +679,26 @@ data.put("nav", gson.toJson(navList)); List<TaoBaoGoodsBriefExtra> re = new ArrayList<TaoBaoGoodsBriefExtra>(); List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs(); + if (taoBaoGoodsBriefs == null) + taoBaoGoodsBriefs = new ArrayList<>(); + + try { + if (daTaoKeList != null && daTaoKeList.size() > 0) { + Collections.reverse(daTaoKeList); + for (DaTaoKeDetail detail : daTaoKeList) { + taoBaoGoodsBriefs.add(0, TaoBaoUtil.convert(detail)); + } + } + } catch (Exception e) { + } + int fq = sf.getQuan(); int fh = sf.getHongbao(); boolean ft = sf.isTmall(); - Map<String, String> map = manageService.convertMap(); BigDecimal proportion = manageService.getFanLiRate(); if (fq == 0 && fh == 0 && !ft) { - if (result != null && result.getTaoBaoGoodsBriefs() != null) - for (TaoBaoGoodsBrief bf : result.getTaoBaoGoodsBriefs()) { + if (result != null && taoBaoGoodsBriefs != null) + for (TaoBaoGoodsBrief bf : taoBaoGoodsBriefs) { int count = bf.getBiz30day(); if (count >= 10000) { // 瀵归攢閲忔暟鎹仛澶勭悊 椤甸潰灞曠ず7.3涓� double sales = count; @@ -909,6 +955,43 @@ return data; } + private JSONObject searchDaTaoKeGoods(String key, int page, String filter, String order, String startprice, + String endprice) { + page = page + 1; + int sort = DaTaoKeApiUtil.SORT_DEFAULT; + if ("5".equalsIgnoreCase(order)) { + sort = DaTaoKeApiUtil.SORT_COMMISSION; + } else if ("1".equalsIgnoreCase(order)) { + sort = DaTaoKeApiUtil.SORT_SALES; + } else if ("2".equalsIgnoreCase(order)) { + sort = DaTaoKeApiUtil.SORT_PRICE_HIGH_TO_LOW; + } else if ("3".equalsIgnoreCase(order)) { + sort = DaTaoKeApiUtil.SORT_PRICE_LOW_TO_HIGH; + } + + List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>(); + BigDecimal proportion = manageService.getFanLiRate(); + + DaTaoKeGoodsResult result = DaTaoKeApiUtil.search(key, null, null, null, page, 20, sort); + if (result != null && result.getGoodsList() != null) + for (DaTaoKeDetailV2 goods : result.getGoodsList()) { + listExtra.add( + TaoBaoUtil.getTaoBaoGoodsBriefExtra(TaoBaoUtil.convert(goods), proportion.toString(), null)); + } + + List<TaoBaoSearchNav> navList = new ArrayList<>(); + Gson gson = new GsonBuilder().create(); + Gson gson2 = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder()) + .excludeFieldsWithoutExposeAnnotation().create(); + + JSONObject data = new JSONObject(); + data.put("nav", gson.toJson(navList)); + data.put("result", gson2.toJson(listExtra)); + data.put("count", result.getTotalCount()); + + return data; + } + /** * 璁剧疆鏌ヨ浣i噾姣斾緥鑼冨洿 * -- Gitblit v1.8.0