From 394c3eb18c7b9a2af63d65a916ed86aad0f7e2c2 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期二, 16 七月 2019 14:51:47 +0800
Subject: [PATCH] 优化

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java |  108 ++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 108 insertions(+), 0 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java
index 3cfb1ec..be43293 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java
@@ -28,6 +28,7 @@
 import com.yeshi.fanli.entity.taobao.TaoBaoShop;
 import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
 import com.yeshi.fanli.entity.taobao.TaoKeAppInfo;
+import com.yeshi.fanli.exception.taobao.TaoKeApiException;
 import com.yeshi.fanli.exception.taobao.TaobaoGoodsDownException;
 import com.yeshi.fanli.exception.taobao.TaobaoGoodsUpdateException;
 import com.yeshi.fanli.log.LogHelper;
@@ -797,5 +798,112 @@
 			}
 		});
 	}
+	
+	
+	/**
+	 * 鍟嗗搧璇︽儏鎺ㄨ崘锛堢寽浣犲枩娆�  +  鎺ㄨ崘锛�
+	 * 
+	 * @param acceptData
+	 * @param id
+	 * @param out
+	 */
+	@RequestMapping(value = "getRecommendGoods", method = RequestMethod.POST)
+	public void getRecommendGoods(AcceptData acceptData, long id, Integer goodsType, PrintWriter out) {
+		if (goodsType == null) {
+			goodsType = Constant.SOURCE_TYPE_TAOBAO;
+		}
+		
+		// 浜笢
+		if (goodsType == Constant.SOURCE_TYPE_JD) {
+			JSONObject data = new JSONObject();
+			data.put("listQuality", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
+			data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
+			out.print(JsonUtil.loadTrueResult(data));
+			return;
+		}
+		
+		// 鎷煎澶�
+		if (goodsType == Constant.SOURCE_TYPE_PDD) {
+			JSONObject data = new JSONObject();
+			data.put("listQuality", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
+			data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
+			out.print(JsonUtil.loadTrueResult(data));
+			return;
+		}
+
+		
+		List<TaoBaoGoodsBrief> goodsList = TaoKeApiUtil.getRelationGoodsRecommend(id, 10);
+		// 鍒濆鍖�
+		if (goodsList == null) {
+			goodsList = new ArrayList<TaoBaoGoodsBrief>();
+		}
+
+
+		List<GoodsDetailVO> listExtra = new ArrayList<GoodsDetailVO>();
+		TaoKeAppInfo app = new TaoKeAppInfo();
+		app.setAppKey(TaoBaoConstant.TAOBAO_AUTH_APPKEY);
+		app.setAppSecret(TaoBaoConstant.TAOBAO_AUTH_APPSECRET);
+		app.setAdzoneId(TaoBaoConstant.TAOBAO_SPECIAL_PID_DEFAULT.split("_")[3]);
+		app.setPid(TaoBaoConstant.TAOBAO_SPECIAL_PID_DEFAULT);
+
+		List<Long> ids = new ArrayList<>();
+		for (TaoBaoGoodsBrief goods : goodsList)
+			ids.add(goods.getAuctionId());
+
+		try {
+			goodsList = TaoKeApiUtil.getBatchGoodsInfo(ids);
+		} catch (TaoKeApiException e1) {
+			e1.printStackTrace();
+		} catch (TaobaoGoodsDownException e1) {
+			e1.printStackTrace();
+		}
+
+		if (goodsList != null && goodsList.size() > 0) {
+			
+			BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
+			BigDecimal shareRate = hongBaoManageService.getShareRate();
+			
+			goodsList.parallelStream().forEach(goods -> {
+				if (goods != null) {
+					// 鑾峰彇璇︽儏
+					TaoBaoGoodsBrief taoBaoGoodsBrief = null;
+					try {
+						taoBaoGoodsBrief = taoBaoGoodsCacheUtil.getCommonTaoBaoGoodsInfo(goods.getAuctionId());
+					} catch (Exception e) {
+						e.printStackTrace();
+					}
+
+					if (taoBaoGoodsBrief == null) {
+						TaoBaoGoodsBrief newGoods = TaoKeApiUtil.specialConvertCoupon(goods.getAuctionId(), app);
+						goods.setCouponInfo(newGoods.getCouponInfo());
+						goods.setCouponLink(newGoods.getCouponLink());
+						goods.setTkRate(newGoods.getTkRate());
+						taoBaoGoodsBrief = goods;
+					}
+
+					if (taoBaoGoodsBrief != null) {
+						listExtra.add(GoodsDetailVOFactory.convertTaoBao(taoBaoGoodsBrief, null, fanLiRate, shareRate));
+					}
+				}
+			});
+		}
+		
+		
+		List<GoodsDetailVO> listQuality = new ArrayList<GoodsDetailVO>();
+		// 鍙栧伓鏁颁釜鏁版嵁
+		if (listExtra.size() % 2 != 0) {
+			listExtra.remove(listExtra.size() - 1);
+		}
+
+		if (listQuality.size() % 2 != 0) {
+			listQuality.remove(listQuality.size() - 1);
+		}
+
+		JSONObject data = new JSONObject();
+		data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listExtra));
+		data.put("listGuess", JsonUtil.getApiCommonGson().toJson(listQuality));
+		out.print(JsonUtil.loadTrueResult(data));
+	}
+
 
 }

--
Gitblit v1.8.0