admin
2020-07-15 fe646416d8d46de7b896ddbf65a3ad0cd30b729b
fanli/src/main/java/com/yeshi/fanli/controller/client/v1/SearchController.java
@@ -10,6 +10,7 @@
import javax.annotation.Resource;
import com.yeshi.fanli.entity.SystemEnum;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@@ -34,7 +35,7 @@
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.DaTaoKeDetailV2;
import com.yeshi.goods.facade.entity.taobao.DaTaoKeDetailV2;
import com.yeshi.fanli.service.inter.config.BusinessSystemService;
import com.yeshi.fanli.service.inter.config.ConfigService;
import com.yeshi.fanli.service.inter.config.HotSearchService;
@@ -82,9 +83,6 @@
   private TaoBaoUnionConfigService taoBaoUnionConfigService;
   @Resource
   private TaoKeGoodsService taoKeGoodsService;
   @Resource
   private QualityGoodsService qualityGoodsService;
   @Resource
@@ -110,7 +108,7 @@
         goodsType = Constant.SOURCE_TYPE_TAOBAO;
      }
      
      List<HotSearch> list = hotSearchService.getHotSearchCache(goodsType);
      List<HotSearch> list = hotSearchService.getHotSearchCache(goodsType,acceptData.getSystem());
      if (list == null || list.size() == 0) {
         out.print(JsonUtil.loadFalseResult("没有数据"));
         return;
@@ -151,7 +149,7 @@
      data.put("nav", gson.toJson(navList));
      List<TaoBaoGoodsBriefExtra> re = new ArrayList<TaoBaoGoodsBriefExtra>();
      List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
      BigDecimal proportion = manageService.getFanLiRate();
      BigDecimal proportion = manageService.getFanLiRate(acceptData.getSystem());
      for (TaoBaoGoodsBrief bf : taoBaoGoodsBriefs) {
         re.add(TaoBaoUtil.getTaoBaoGoodsBriefExtra(bf, proportion.toString(), ""));
      }
@@ -176,7 +174,7 @@
      String bid = getHistorySearchBid(acceptData);
      historySearchService.addHistorySearch(kw, bid);
      BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(),
            acceptData.getPackages());
            acceptData.getPackages(),acceptData.getSystem());
      if (system == null) {
         out.print(JsonUtil.loadFalseResult("系统不存在"));
         return;
@@ -197,7 +195,7 @@
            filter = fastFilter;
         }
      }
      JSONObject data = search(kw, page, filter, order, startprice, endprice);
      JSONObject data = search(acceptData, kw, page, filter, order, startprice, endprice);
      out.print(JsonUtil.loadTrueResult(data));
   }
@@ -205,11 +203,11 @@
   public JSONObject searchClass(AcceptData acceptData, String kw, int page, String filter, String order,
         String startprice, String endprice, String md5) {
      java.lang.System.out.println("searchClass");
      JSONObject data = search(kw, page, filter, order, startprice, endprice);
      JSONObject data = search(acceptData, kw, page, filter, order, startprice, endprice);
      return data;
   }
   private JSONObject search(String kw, int page, String filter, String order, String startprice, String endprice) {
   private JSONObject search(AcceptData acceptData, String kw, int page, String filter, String order, String startprice, String endprice) {
      page = page + 1;
      SearchFilter sf = new SearchFilter();
@@ -325,7 +323,7 @@
      int fq = sf.getQuan();
      int fh = sf.getHongbao();
      boolean ft = sf.isTmall();
      BigDecimal proportion = manageService.getFanLiRate();
      BigDecimal proportion = manageService.getFanLiRate(acceptData.getSystem());
      if (fq == 0 && fh == 0 && !ft) {
         if (result != null && result.getTaoBaoGoodsBriefs() != null)
            for (TaoBaoGoodsBrief bf : result.getTaoBaoGoodsBriefs()) {
@@ -458,14 +456,13 @@
      JSONObject data = null;
      if (!recommend) {
         // 淘宝接口请求
         data = searchGoods(kw, page, filter, order, startprice, endprice);
         data = searchGoods(acceptData, kw, page, filter, order, startprice, endprice,acceptData.getSystem());
      } else {
         // 推荐:精选库
         // data = searchQualityGoods(kw, page, filter, order, startprice,
         // endprice);
         data = searchDaTaoKeGoods(kw, page, filter, order, startprice, endprice);
         data = searchDaTaoKeGoods(acceptData, kw, page, filter, order, startprice, endprice);
      }
      // 获取推荐词
@@ -477,7 +474,7 @@
            listRecommendWords = new ArrayList<String>();
         }
         List<TaoBaoShopVO> listShop =taoBaoShopService.getShopByKey(kw);
         List<TaoBaoShopVO> listShop =taoBaoShopService.getShopByKey(kw,acceptData.getSystem());
         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)));
@@ -502,8 +499,8 @@
    * @param endprice
    * @return
    */
   private JSONObject searchGoods(String kw, int page, String filter, String order, String startprice,
         String endprice) {
   private JSONObject searchGoods(AcceptData acceptData, String kw, int page, String filter, String order, String startprice,
         String endprice,SystemEnum system) {
      page = page + 1;
      SearchFilter sf = new SearchFilter();
@@ -606,15 +603,15 @@
               int id = array.optJSONObject(i).optInt("id");
               sf.setProvinceId(id);
            } else if ("tkRate1".equalsIgnoreCase(ty)) {
               setSearchTkRate(0, sf);
               setSearchTkRate(0, sf,system);
            } else if ("tkRate2".equalsIgnoreCase(ty)) {
               setSearchTkRate(1, sf);
               setSearchTkRate(1, sf,system);
            } else if ("tkRate3".equalsIgnoreCase(ty)) {
               setSearchTkRate(2, sf);
               setSearchTkRate(2, sf,system);
            } else if ("tkRate4".equalsIgnoreCase(ty)) {
               setSearchTkRate(3, sf);
               setSearchTkRate(3, sf,system);
            } else if ("tkRate5".equalsIgnoreCase(ty)) {
               setSearchTkRate(4, sf);
               setSearchTkRate(4, sf,system);
            }
         }
         sf.setParams(params);
@@ -685,7 +682,7 @@
      int fq = sf.getQuan();
      int fh = sf.getHongbao();
      boolean ft = sf.isTmall();
      BigDecimal proportion = manageService.getFanLiRate();
      BigDecimal proportion = manageService.getFanLiRate(acceptData.getSystem());
      if (fq == 0 && fh == 0 && !ft) {
         if (result != null && taoBaoGoodsBriefs != null)
            for (TaoBaoGoodsBrief bf : taoBaoGoodsBriefs) {
@@ -730,7 +727,7 @@
   /**
    * 执行搜索精选库
    * 
    * @param kw
    * @param key
    * @param page
    * @param filter
    * @param order
@@ -738,8 +735,8 @@
    * @param endprice
    * @return
    */
   private JSONObject searchQualityGoods(String key, int page, String filter, String order, String startprice,
         String endprice) {
   private JSONObject searchQualityGoods(AcceptData acceptData, String key, int page, String filter, String order, String startprice,
                                String endprice, SystemEnum system) {
      Integer hasQuan = null;
      Integer userType = null;
@@ -788,7 +785,7 @@
               provinceId = array.optJSONObject(i).optInt("id");
            } else if ("tkRate1".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
               String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
@@ -804,7 +801,7 @@
               }
            } else if ("tkRate2".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
               String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
@@ -820,7 +817,7 @@
               }
            } else if ("tkRate3".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
               String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
@@ -836,7 +833,7 @@
               }
            } else if ("tkRate4".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
               String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
@@ -852,7 +849,7 @@
               }
            } else if ("tkRate5".equalsIgnoreCase(ty)) {
               // 获取对应参数
               String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
               String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
               if (!StringUtil.isNullOrEmpty(value)) {
                  JSONArray tkRatearray = JSONArray.fromObject(value);
                  if (tkRatearray != null) {
@@ -876,7 +873,7 @@
            userType, start_Price, end_Price, startTkRate, endTkRate, sort);
      List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>();
      BigDecimal proportion = manageService.getFanLiRate();
      BigDecimal proportion = manageService.getFanLiRate(acceptData.getSystem());
      /* 遍历列表数据 */
      if (listQuery != null && listQuery.size() > 0) {
         for (QualityFactory selectionGoods : listQuery) {
@@ -945,7 +942,7 @@
      return data;
   }
   private JSONObject searchDaTaoKeGoods(String key, int page, String filter, String order, String startprice,
   private JSONObject searchDaTaoKeGoods(AcceptData acceptData, String key, int page, String filter, String order, String startprice,
         String endprice) {
      page = page + 1;
      int sort = DaTaoKeApiUtil.SORT_DEFAULT;
@@ -960,7 +957,7 @@
      }
      List<TaoBaoGoodsBriefExtra> listExtra = new ArrayList<TaoBaoGoodsBriefExtra>();
      BigDecimal proportion = manageService.getFanLiRate();
      BigDecimal proportion = manageService.getFanLiRate(acceptData.getSystem());
      DaTaoKeGoodsResult result = DaTaoKeApiUtil.search(key, null, null, null, page, 20, sort);
      if (result != null && result.getGoodsList() != null)
@@ -988,9 +985,9 @@
    * @param i
    * @param sf
    */
   public void setSearchTkRate(int i, SearchFilter sf) {
   public void setSearchTkRate(int i, SearchFilter sf,SystemEnum system) {
      // 获取对应参数
      String value = configService.get(ConfigKeyEnum.tkRateRange.getKey());
      String value = configService.getValue(ConfigKeyEnum.tkRateRange.getKey(),system);
      if (!StringUtil.isNullOrEmpty(value)) {