From 01e773cf27e572b8fb83538d85f31130930d93d1 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期四, 15 八月 2019 15:57:23 +0800
Subject: [PATCH] 券赠送

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/GoodsControllerV2.java |  281 +++++++++++++++++++++++++++++---------------------------
 1 files changed, 146 insertions(+), 135 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 9bcb0a4..b48198e 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
@@ -7,6 +7,7 @@
 
 import javax.annotation.Resource;
 
+import org.json.simple.JSONArray;
 import org.springframework.stereotype.Controller;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RequestMethod;
@@ -719,7 +720,7 @@
 		if (couponInfo != null) {
 			convertUrl = PinDuoDuoApiUtil.convert(id, PinDuoDuoApiUtil.PID_COUPON + "", null);
 			if (convertUrl != null)
-				couponInfo.setLink(convertUrl.getShortUrl());
+				couponInfo.setLink(convertUrl.getUrl());
 		}
 
 		ShopInfoVO shopInfo = goodsDetail.getShopInfo();
@@ -747,7 +748,7 @@
 			if (indexOf > 0) {
 				salesTip = salesTip.substring(0, indexOf);
 			}
-			
+
 			int totalSales = 0;
 			if (salesTip.contains("涓�")) {
 				salesTip = salesTip.substring(0, salesTip.indexOf("涓�"));
@@ -807,7 +808,7 @@
 		extraVO.setShare(shareInfoVO);
 
 		if (convertUrl != null) {
-			extraVO.setCouponJumpLink(convertUrl.getShortUrl());
+			extraVO.setCouponJumpLink(convertUrl.getUrl());
 			extraVO.setNativeCouponJumpLink(PinDuoDuoUtil.getAndroidNativeURI(convertUrl.getUrl()));
 		}
 
@@ -841,148 +842,158 @@
 			goodsType = Constant.SOURCE_TYPE_TAOBAO;
 		}
 
-		// 浜笢
-		if (goodsType == Constant.SOURCE_TYPE_JD) {
-			JSONObject data = new JSONObject();
-			data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
-
-			List<JDGoods> list = JDUtil.getRecommendGoodsById(id);
-			if (list == null) {
-				list = new ArrayList<JDGoods>();
-			} else if (list.size() > 10) {
-				list = list.subList(0, 10);
-			}
-
-			BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
-			BigDecimal shareRate = hongBaoManageService.getShareRate();
-			List<GoodsDetailVO> listDetailVO = new ArrayList<GoodsDetailVO>();
-
-			for (JDGoods goods : list) {
-				listDetailVO.add(GoodsDetailVOFactory.convertJDGoods(goods, fanLiRate, shareRate));
-			}
-
-			// 鍙栧伓鏁颁釜鏁版嵁
-			if (listDetailVO.size() % 2 != 0) {
-				listDetailVO.remove(listDetailVO.size() - 1);
-			}
-
-			data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listDetailVO));
-			out.print(JsonUtil.loadTrueResult(data));
-			return;
-		}
-
-		// 鎷煎澶�
-		if (goodsType == Constant.SOURCE_TYPE_PDD) {
-			JSONObject data = new JSONObject();
-			data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
-
-			List<GoodsDetailVO> listDetailVO = new ArrayList<GoodsDetailVO>();
-
-			List<Long> goodsIdList = PinDuoDuoUtil.getRecommendGoodsId(id);
-			if (goodsIdList != null && goodsIdList.size() > 0) {
-				PDDSearchFilter pddfilter = new PDDSearchFilter();
-				pddfilter.setPage(1);
-				pddfilter.setPageSize(Constant.PAGE_SIZE);
-				Long[] strings = new Long[goodsIdList.size()];
-				pddfilter.setGoodsIdList(goodsIdList.toArray(strings));
-
-				PDDGoodsResult result = PinDuoDuoApiUtil.searchGoods(pddfilter);
-				if (result != null) {
-					List<PDDGoodsDetail> goodsList = result.getGoodsList();
-					if (goodsList != null && goodsList.size() > 0) {
-
-						if (goodsList.size() > 10) {
-							goodsList = goodsList.subList(0, 10);
-						}
-
-						BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
-						BigDecimal shareRate = hongBaoManageService.getShareRate();
-						for (PDDGoodsDetail goods : goodsList) {
-							listDetailVO.add(GoodsDetailVOFactory.convertPDDGoods(goods, fanLiRate, shareRate));
-						}
-					}
-				}
-			}
-
-			// 鍙栧伓鏁颁釜鏁版嵁
-			if (listDetailVO.size() % 2 != 0) {
-				listDetailVO.remove(listDetailVO.size() - 1);
-			}
-
-			data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listDetailVO));
-			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) {
+			// 浜笢
+			if (goodsType == Constant.SOURCE_TYPE_JD) {
+				JSONObject data = new JSONObject();
+				data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
 
-			BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
-			BigDecimal shareRate = hongBaoManageService.getShareRate();
+				List<JDGoods> list = JDUtil.getRecommendGoodsById(id);
+				if (list == null) {
+					list = new ArrayList<JDGoods>();
+				} else if (list.size() > 10) {
+					list = list.subList(0, 10);
+				}
 
-			goodsList.parallelStream().forEach(goods -> {
-				if (goods != null) {
-					// 鑾峰彇璇︽儏
-					TaoBaoGoodsBrief taoBaoGoodsBrief = null;
-					try {
-						taoBaoGoodsBrief = taoBaoGoodsCacheUtil.getCommonTaoBaoGoodsInfo(goods.getAuctionId());
-					} catch (Exception e) {
-						e.printStackTrace();
-					}
+				BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
+				BigDecimal shareRate = hongBaoManageService.getShareRate();
+				List<GoodsDetailVO> listDetailVO = new ArrayList<GoodsDetailVO>();
 
-					if (taoBaoGoodsBrief == null) {
-						TaoBaoGoodsBrief newGoods = TaoKeApiUtil.specialConvertCoupon(goods.getAuctionId(), app);
-						goods.setCouponInfo(newGoods.getCouponInfo());
-						goods.setCouponLink(newGoods.getCouponLink());
-						goods.setTkRate(newGoods.getTkRate());
-						taoBaoGoodsBrief = goods;
-					}
+				for (JDGoods goods : list) {
+					listDetailVO.add(GoodsDetailVOFactory.convertJDGoods(goods, fanLiRate, shareRate));
+				}
 
-					if (taoBaoGoodsBrief != null) {
-						listExtra.add(GoodsDetailVOFactory.convertTaoBao(taoBaoGoodsBrief, null, fanLiRate, shareRate));
+				// 鍙栧伓鏁颁釜鏁版嵁
+				if (listDetailVO.size() % 2 != 0) {
+					listDetailVO.remove(listDetailVO.size() - 1);
+				}
+
+				data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listDetailVO));
+				out.print(JsonUtil.loadTrueResult(data));
+				return;
+			}
+
+			// 鎷煎澶�
+			if (goodsType == Constant.SOURCE_TYPE_PDD) {
+				JSONObject data = new JSONObject();
+				data.put("listGuess", JsonUtil.getApiCommonGson().toJson(new ArrayList<GoodsDetailVO>()));
+
+				List<GoodsDetailVO> listDetailVO = new ArrayList<GoodsDetailVO>();
+
+				List<Long> goodsIdList = PinDuoDuoUtil.getRecommendGoodsId(id);
+				if (goodsIdList != null && goodsIdList.size() > 0) {
+					PDDSearchFilter pddfilter = new PDDSearchFilter();
+					pddfilter.setPage(1);
+					pddfilter.setPageSize(Constant.PAGE_SIZE);
+					Long[] strings = new Long[goodsIdList.size()];
+					pddfilter.setGoodsIdList(goodsIdList.toArray(strings));
+
+					PDDGoodsResult result = PinDuoDuoApiUtil.searchGoods(pddfilter);
+					if (result != null) {
+						List<PDDGoodsDetail> goodsList = result.getGoodsList();
+						if (goodsList != null && goodsList.size() > 0) {
+
+							if (goodsList.size() > 10) {
+								goodsList = goodsList.subList(0, 10);
+							}
+
+							BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
+							BigDecimal shareRate = hongBaoManageService.getShareRate();
+							for (PDDGoodsDetail goods : goodsList) {
+								listDetailVO.add(GoodsDetailVOFactory.convertPDDGoods(goods, fanLiRate, shareRate));
+							}
+						}
 					}
 				}
-			});
-		}
 
-		List<GoodsDetailVO> listQuality = new ArrayList<GoodsDetailVO>();
-		// 鍙栧伓鏁颁釜鏁版嵁
-		if (listExtra.size() % 2 != 0) {
-			listExtra.remove(listExtra.size() - 1);
-		}
+				// 鍙栧伓鏁颁釜鏁版嵁
+				if (listDetailVO.size() % 2 != 0) {
+					listDetailVO.remove(listDetailVO.size() - 1);
+				}
 
-		if (listQuality.size() % 2 != 0) {
-			listQuality.remove(listQuality.size() - 1);
-		}
+				data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listDetailVO));
+				out.print(JsonUtil.loadTrueResult(data));
+				return;
+			}
 
-		JSONObject data = new JSONObject();
-		data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listExtra));
-		data.put("listGuess", JsonUtil.getApiCommonGson().toJson(listQuality));
-		out.print(JsonUtil.loadTrueResult(data));
+			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));
+		} catch (Exception e) {
+			LogHelper.errorDetailInfo(e);
+			JSONObject data = new JSONObject();
+			data.put("listQuality", new JSONArray());
+			data.put("listGuess", new JSONArray());
+			out.print(JsonUtil.loadTrueResult(data));
+		}
 	}
 
 	/**
@@ -1070,7 +1081,7 @@
 		PDDPromotionUrl convertUrl = PinDuoDuoApiUtil.convert(id, PinDuoDuoApiUtil.PID_FANLI + "", uid + "");
 		JSONObject data = new JSONObject();
 		data.put("native", true);
-		data.put("jumpLink", convertUrl.getShortUrl());
+		data.put("jumpLink", convertUrl.getUrl());
 		data.put("nativeJumpLink", PinDuoDuoUtil.getAndroidNativeURI(convertUrl.getUrl()));
 		out.print(JsonUtil.loadTrueResult(data));
 	}

--
Gitblit v1.8.0