From cdd852f8e8eff7eb2e8f7c3fceaa955b9fc3f9d3 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期一, 29 七月 2019 10:46:32 +0800
Subject: [PATCH] 订单商品类型处理

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java |  298 ++++++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 182 insertions(+), 116 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java
index f1f274f..1c8c745 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java
@@ -20,6 +20,7 @@
 
 import com.google.gson.Gson;
 import com.google.gson.GsonBuilder;
+import com.yeshi.fanli.dto.jd.JDFilter;
 import com.yeshi.fanli.dto.jd.JDSearchFilter;
 import com.yeshi.fanli.dto.jd.JDSearchResult;
 import com.yeshi.fanli.dto.pdd.PDDGoodsDetail;
@@ -49,6 +50,7 @@
 import com.yeshi.fanli.util.Utils;
 import com.yeshi.fanli.util.cache.TaoBaoGoodsCacheUtil;
 import com.yeshi.fanli.util.factory.goods.GoodsDetailVOFactory;
+import com.yeshi.fanli.util.jd.JDApiUtil;
 import com.yeshi.fanli.util.jd.JDUtil;
 import com.yeshi.fanli.util.pinduoduo.PinDuoDuoApiUtil;
 import com.yeshi.fanli.util.pinduoduo.PinDuoDuoUtil;
@@ -96,12 +98,10 @@
 
 	@Resource
 	private DaTaoKeGoodsDetailService daTaoKeGoodsDetailService;
-	
+
 	@Resource(name = "taskExecutor")
 	private TaskExecutor executor;
 
-	
-	
 	/**
 	 * 绮樿创鏉夸俊鎭帹鑽�
 	 * 
@@ -143,37 +143,13 @@
 				out.print(JsonUtil.loadFalseResult("鍊艰繃闀�"));
 				return;
 			}
-
-			SearchFilter sf = new SearchFilter();
-			sf.setKey(text);
 			JSONObject root = new JSONObject();
 
-			TaoBaoSearchResult result = TaoBaoUtil.search(sf);
-			if (result != null && result.getTaoBaoGoodsBriefs() != null && result.getTaoBaoGoodsBriefs().size() > 0)
-				for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) {
-					// 鏄睘浜庢窐瀹濊仈鐩熷晢鍝�
-					if (goods.getTitle().equalsIgnoreCase(text)) {
-						root.put("type", 2);
-						JSONObject data = new JSONObject();
-						data.put("title", goods.getTitle());
-						root.put("data", data);
-						out.print(JsonUtil.loadTrueResult(root));
-						return;
-					}
-				}
-
-			// 鏌ヨ澶ф窐瀹㈡爣棰�
-			List<DaTaoKeDetail> list = daTaoKeGoodsDetailService.listByDtitle(text);
-			if (list != null && list.size() > 0) {
-				root.put("type", 2);
-				JSONObject data = new JSONObject();
-				data.put("title", list.get(0).getdTitle());
-				root.put("data", data);
-				out.print(JsonUtil.loadTrueResult(root));
-				return;
-			}
-
-			out.print(JsonUtil.loadFalseResult("鏆備笉鏀寔璇ョ被鍨嬶紒"));
+			root.put("type", 2);
+			JSONObject data = new JSONObject();
+			data.put("title", text);
+			root.put("data", data);
+			out.print(JsonUtil.loadTrueResult(root));
 			return;
 		}
 
@@ -234,9 +210,7 @@
 
 		out.print(JsonUtil.loadTrueResult(root));
 	}
-	
-	
-	
+
 	/**
 	 * 鎼滅储鍊欓�夎瘝
 	 * 
@@ -279,32 +253,33 @@
 	 * @param kw
 	 * @param page
 	 * @param filter
-	 * @param order      閿�閲忕敱楂樺埌浣�:1 銆� 浠锋牸浠庨珮鍒颁綆:2 銆� 浠锋牸浠庝綆鍒伴珮:3 銆� 鎺ㄥ箍閲忛珮鍒颁綆:4锛堢患鍚堥粯璁わ級銆佽繑鍒╂瘮楂樺埌浣�:5
-	 *                   銆佽繑鍒╂瘮浣庡埌楂�:6 銆佹帹鑽�20
+	 * @param order
+	 *            閿�閲忕敱楂樺埌浣�:1 銆� 浠锋牸浠庨珮鍒颁綆:2 銆� 浠锋牸浠庝綆鍒伴珮:3 銆� 鎺ㄥ箍閲忛珮鍒颁綆:4锛堢患鍚堥粯璁わ級銆佽繑鍒╂瘮楂樺埌浣�:5
+	 *            銆佽繑鍒╂瘮浣庡埌楂�:6 銆佹帹鑽�20
 	 * @param startprice
 	 * @param endprice
 	 * @param fastFilter
 	 * @param out
 	 */
 	@RequestMapping(value = "searchGoods")
-	public void searchGoods(AcceptData acceptData, Integer goodsType, String key, Integer page, String filter, Integer order, 
-			PrintWriter out) {
-		if (goodsType == null || goodsType < 1 || goodsType >3) {
+	public void searchGoods(AcceptData acceptData, Integer goodsType, String key, Integer page, String filter,
+			Integer order, PrintWriter out) {
+		if (goodsType == null || goodsType < 1 || goodsType > 3) {
 			out.print(JsonUtil.loadFalseResult(1, "璇蜂紶閫掓纭钩鍙板弬鏁�"));
 			return;
 		}
-		
+
 		if (page == null || page < 1) {
 			out.print(JsonUtil.loadFalseResult(1, "椤电爜涓嶈兘灏忎簬1"));
 			return;
 		}
-		
+
 		if (StringUtil.isNullOrEmpty(key)) {
 			out.print(JsonUtil.loadFalseResult(1, "璇疯緭鍏ユ悳绱㈠唴瀹�"));
 			return;
 		}
 		final String searchkey = key.trim();
-		
+
 		executor.execute(new Runnable() {
 			@Override
 			public void run() {
@@ -315,12 +290,11 @@
 				String device = acceptData.getDevice();
 				sb.append(platform).append(link).append(packages).append(link).append(device);
 				String bid = StringUtil.Md5(sb.toString());
-				
+
 				// 鍔犲叆鎼滅储鍘嗗彶璁板綍
 				historySearchService.addHistorySearch(searchkey, bid);
 			}
 		});
-		
 
 		if (searchkey.startsWith("http://") || searchkey.startsWith("https://")) {
 			JSONObject data = new JSONObject();
@@ -330,19 +304,19 @@
 			return;
 		}
 
-		/*--------- 浜笢鍟嗗搧  -------*/ 
+		/*--------- 浜笢鍟嗗搧  -------*/
 		if (goodsType.intValue() == Constant.SOURCE_TYPE_JD) {
 			searchJDGoods(searchkey, page, filter, order, out);
 			return;
 		}
 
-		/*-------- 鎷煎澶氬晢鍝�  -------*/ 
+		/*-------- 鎷煎澶氬晢鍝�  -------*/
 		if (goodsType.intValue() == Constant.SOURCE_TYPE_PDD) {
 			searchPDDGoods(searchkey, page, filter, order, out);
 			return;
 		}
 
-		/*-------- 娣樺疂鍟嗗搧  -------*/ 
+		/*-------- 娣樺疂鍟嗗搧  -------*/
 		searchTaoBaoGoods(searchkey, page, filter, order, out);
 	}
 
@@ -373,18 +347,28 @@
 			} else if (order == 4) { // 杩斿埄姣旈珮鍒颁綆
 				sf.setSort(TaoBaoUtil.SORT_TKRATE_HIGH_TO_LOW);
 			}
-		} 
-		
+		}
 
 		if (!StringUtil.isNullOrEmpty(filter)) {
-			JSONArray array = JSONArray.fromObject(filter);
-			for (int i = 0; i < array.size(); i++) {
-				String ty = array.optJSONObject(i).optString("type");
-				if ("coupon".equalsIgnoreCase(ty)) { // 鏈夊埜
-					sf.setQuan(1);
-				} else if ("tmall".equalsIgnoreCase(ty)) { // 澶╃尗
-					sf.setTmall(true);
-				} 
+			JSONObject jsonfilter = JSONObject.fromObject(filter);
+			Boolean coupon = jsonfilter.optBoolean("coupon");
+			if (coupon != null && coupon) {
+				sf.setQuan(1); // 鏈夊埜
+			}
+
+			Boolean tmall = jsonfilter.optBoolean("tmall");
+			if (tmall != null && tmall) {
+				sf.setTmall(true); // 澶╃尗
+			}
+
+			String minPrice = jsonfilter.optString("minPrice");
+			if (!StringUtil.isNullOrEmpty(minPrice)) {
+				sf.setStartPrice(new BigDecimal(minPrice));
+			}
+
+			String maxPrice = jsonfilter.optString("maxPrice");
+			if (!StringUtil.isNullOrEmpty(maxPrice)) {
+				sf.setEndPrice(new BigDecimal(maxPrice));
 			}
 		}
 
@@ -393,10 +377,10 @@
 		if (page == 1) {
 			daTaoKeList = daTaoKeGoodsDetailService.listByDtitle(key);
 		}
-		
+
 		// 娣樺疂api鎼滅储鍟嗗搧
 		TaoBaoSearchResult result = TaoBaoUtil.search(sf);
-		
+
 		// 鎼滅储鏄惁鍦ㄨ惀閿�涓诲晢鍝佸簱
 		if (result != null && result.getTaoBaoGoodsBriefs() != null && result.getTaoBaoGoodsBriefs().size() > 0) {
 			ThreadUtil.run(new Runnable() {
@@ -408,7 +392,7 @@
 				}
 			});
 		}
-		
+
 		List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = null;
 		if (result != null) {
 			taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
@@ -416,7 +400,7 @@
 		if (taoBaoGoodsBriefs == null) {
 			taoBaoGoodsBriefs = new ArrayList<>();
 		}
-	
+
 		if (daTaoKeList != null && daTaoKeList.size() > 0) {
 			try {
 				Collections.reverse(daTaoKeList);
@@ -426,7 +410,7 @@
 			} catch (Exception e) {
 			}
 		}
-		
+
 		List<GoodsDetailVO> list = new ArrayList<GoodsDetailVO>();
 		BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
 		BigDecimal shareRate = hongBaoManageService.getShareRate();
@@ -436,7 +420,7 @@
 
 		Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
 				.excludeFieldsWithoutExposeAnnotation().create();
-		
+
 		JSONObject data = new JSONObject();
 		data.put("result", gson.toJson(list));
 		data.put("count", result.getTaoBaoHead().getDocsfound());
@@ -452,7 +436,6 @@
 		out.print(JsonUtil.loadTrueResult(data));
 	}
 
-
 	/**
 	 * 浜笢
 	 * 
@@ -465,54 +448,136 @@
 	 * @return
 	 */
 	private void searchJDGoods(String key, Integer page, String filter, Integer order, PrintWriter out) {
-		JDSearchFilter jdfilter = new JDSearchFilter();
-		jdfilter.setKey(SearchFilterUtil.filterSearchContent(key));
-		jdfilter.setPageNo(page);
-		jdfilter.setPageSize(Constant.PAGE_SIZE);
 
-		if (order != null) {
-			int sort = order.intValue();
-			switch (sort) {
-			case 1: // 閿�閲� desc
-				jdfilter.setSort(JDSearchFilter.SORT_DESC);
-				jdfilter.setSortName(JDSearchFilter.SORTNAME_ORDER_COUNT_30DAYS);
-				break;
-			case 2: // 浠锋牸鈥攄esc
-				jdfilter.setSort(JDSearchFilter.SORT_DESC);
-				jdfilter.setSortName(JDSearchFilter.SORTNAME_PRICE);
-				break;
-			case 3: // 浠锋牸鈥攁sc
-				jdfilter.setSort(JDSearchFilter.SORT_ASC);
-				jdfilter.setSortName(JDSearchFilter.SORTNAME_PRICE);
-				break;
-			case 4: // 杩斿埄姣斺�擠ESC
-				jdfilter.setSort(JDSearchFilter.SORT_DESC);
-				jdfilter.setSortName(JDSearchFilter.SORTNAME_COMMISSION_SHARE);
-				break;
-			default:
-				break;
-			}
-		}
+		JDSearchResult result = null;
+		String way = configService.get("jd_api_search_key");
+		if ("1".equals(way)) {
+			JDFilter filterAPI = new JDFilter();
+			filterAPI.setKeyword(SearchFilterUtil.filterSearchContent(key));
+			filterAPI.setPageIndex(page);
+			filterAPI.setPageSize(Constant.PAGE_SIZE);
 
-
-		if (!StringUtil.isNullOrEmpty(filter)) {
-			JSONArray array = JSONArray.fromObject(filter);
-			for (int i = 0; i < array.size(); i++) {
-				String ty = array.optJSONObject(i).optString("type");
-				if ("coupon".equalsIgnoreCase(ty)) {
-					jdfilter.setHasCoupon(1); // 鏈夊埜
-				} else if ("zy".equalsIgnoreCase(ty)) {
-					jdfilter.setIsZY(1); // 鏄惁鑷惀
-				} else if ("delivery".equalsIgnoreCase(ty)) {
-					jdfilter.setDeliveryType(1); // 鏄惁浜笢閰嶉��
+			if (order != null) {
+				int sort = order.intValue();
+				switch (sort) {
+				case 1: // 閿�閲� desc
+					filterAPI.setSort(JDFilter.SORT_DESC);
+					filterAPI.setSortName(JDFilter.SORTNAME_ORDER_COUNT_30DAYS);
+					break;
+				case 2: // 浠锋牸鈥攄esc
+					filterAPI.setSort(JDFilter.SORT_DESC);
+					filterAPI.setSortName(JDFilter.SORTNAME_PRICE);
+					break;
+				case 3: // 浠锋牸鈥攁sc
+					filterAPI.setSort(JDFilter.SORT_ASC);
+					filterAPI.setSortName(JDFilter.SORTNAME_PRICE);
+					break;
+				case 4: // 杩斿埄姣斺�擠ESC
+					filterAPI.setSort(JDFilter.SORT_DESC);
+					filterAPI.setSortName(JDFilter.SORTNAME_COMMISSION_SHARE);
+					break;
+				default:
+					break;
 				}
 			}
+
+			if (!StringUtil.isNullOrEmpty(filter)) {
+				JSONObject jsonfilter = JSONObject.fromObject(filter);
+				Boolean coupon = jsonfilter.optBoolean("coupon");
+				if (coupon != null && coupon) {
+					filterAPI.setIsCoupon(1); // 鏈夊埜
+				}
+
+				Boolean zy = jsonfilter.optBoolean("zy");
+				if (zy != null && zy) {
+					filterAPI.setOwner("g"); // 鑷惀
+				}
+
+				String minPrice = jsonfilter.optString("minPrice");
+				if (!StringUtil.isNullOrEmpty(minPrice)) {
+					filterAPI.setPricefrom(Double.parseDouble(minPrice));
+				}
+
+				String maxPrice = jsonfilter.optString("maxPrice");
+				if (!StringUtil.isNullOrEmpty(maxPrice)) {
+					filterAPI.setPriceto(Double.parseDouble(maxPrice));
+				}
+			}
+
+			result = JDApiUtil.queryByKey(filterAPI);
+		} else {
+			// 缃戦〉鐖彇
+			JDSearchFilter jdfilter = new JDSearchFilter();
+			jdfilter.setKey(SearchFilterUtil.filterSearchContent(key));
+			jdfilter.setPageNo(page);
+			jdfilter.setPageSize(Constant.PAGE_SIZE);
+
+			if (order != null) {
+				int sort = order.intValue();
+				switch (sort) {
+				case 1: // 閿�閲� desc
+					jdfilter.setSort(JDSearchFilter.SORT_DESC);
+					jdfilter.setSortName(JDSearchFilter.SORTNAME_ORDER_COUNT_30DAYS);
+					break;
+				case 2: // 浠锋牸鈥攄esc
+					jdfilter.setSort(JDSearchFilter.SORT_DESC);
+					jdfilter.setSortName(JDSearchFilter.SORTNAME_PRICE);
+					break;
+				case 3: // 浠锋牸鈥攁sc
+					jdfilter.setSort(JDSearchFilter.SORT_ASC);
+					jdfilter.setSortName(JDSearchFilter.SORTNAME_PRICE);
+					break;
+				case 4: // 杩斿埄姣斺�擠ESC
+					jdfilter.setSort(JDSearchFilter.SORT_DESC);
+					jdfilter.setSortName(JDSearchFilter.SORTNAME_COMMISSION_SHARE);
+					break;
+				default:
+					break;
+				}
+			}
+
+			if (!StringUtil.isNullOrEmpty(filter)) {
+				JSONObject jsonfilter = JSONObject.fromObject(filter);
+				Boolean coupon = jsonfilter.optBoolean("coupon");
+				if (coupon != null && coupon) {
+					jdfilter.setHasCoupon(1); // 鏈夊埜
+				}
+
+				Boolean zy = jsonfilter.optBoolean("zy");
+				if (zy != null && zy) {
+					jdfilter.setIsZY(1); // 鑷惀
+				}
+
+				Boolean delivery = jsonfilter.optBoolean("delivery");
+				if (delivery != null && delivery) {
+					jdfilter.setDeliveryType(1); // 浜笢閰嶉��
+				}
+
+				String minPrice = jsonfilter.optString("minPrice");
+				if (!StringUtil.isNullOrEmpty(minPrice)) {
+					if (minPrice.contains(".")) {
+						minPrice = minPrice.replace(".", "-");
+						minPrice = minPrice.split("-")[0];
+					}
+					jdfilter.setFromPrice(Integer.parseInt(minPrice));
+				}
+
+				String maxPrice = jsonfilter.optString("maxPrice");
+				if (!StringUtil.isNullOrEmpty(maxPrice)) {
+					if (maxPrice.contains(".")) {
+						maxPrice = maxPrice.replace(".", "-");
+						maxPrice = maxPrice.split("-")[0];
+					}
+					jdfilter.setToPrice(Integer.parseInt(maxPrice));
+				}
+			}
+			result = JDUtil.searchByKey(jdfilter);
+
 		}
 
 		long count = 0;
 		JSONObject data = new JSONObject();
 		JSONArray array = new JSONArray();
-		JDSearchResult result = JDUtil.searchByKey(jdfilter);
 		if (result != null) {
 			PageEntity pageEntity = result.getPageEntity();
 			if (pageEntity != null) {
@@ -539,7 +604,7 @@
 	}
 
 	/**
-	 * 浜笢
+	 *   鎷煎澶�
 	 * 
 	 * @param kw
 	 * @param page
@@ -575,16 +640,17 @@
 				break;
 			}
 		}
-		
+
 		if (!StringUtil.isNullOrEmpty(filter)) {
-			JSONArray array = JSONArray.fromObject(filter);
-			for (int i = 0; i < array.size(); i++) {
-				String ty = array.optJSONObject(i).optString("type");
-				if ("coupon".equalsIgnoreCase(ty)) {
-					pddfilter.setHasCoupon(true); // 鏈夊埜
-				} else if ("brand".equalsIgnoreCase(ty)) {
-					pddfilter.setIsBrand(true); // 鏄惁鏄搧鐗�
-				}
+			JSONObject jsonfilter = JSONObject.fromObject(filter);
+			Boolean coupon = jsonfilter.optBoolean("coupon");
+			if (coupon != null && coupon) {
+				pddfilter.setHasCoupon(true); // 鏈夊埜
+			}
+
+			Boolean brand = jsonfilter.optBoolean("brand");
+			if (brand != null && brand) {
+				pddfilter.setIsBrand(true); // 鏄惁鏄搧鐗�
 			}
 		}
 
@@ -595,12 +661,12 @@
 		PDDGoodsResult result = PinDuoDuoApiUtil.searchGoods(pddfilter);
 		if (result != null) {
 			count = result.getTotalCount();
+			Gson gson = JsonUtil.getApiCommonGson();
 			List<PDDGoodsDetail> goodsList = result.getGoodsList();
 			if (goodsList != null && goodsList.size() > 0) {
 				BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
 				BigDecimal shareRate = hongBaoManageService.getShareRate();
-				Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
-						.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
+
 				for (PDDGoodsDetail goods : goodsList) {
 					GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertPDDGoods(goods, null, fanLiRate,
 							shareRate);

--
Gitblit v1.8.0