From 5a80c35e42ba1ed7340097ea9b156016e52a23f2 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期一, 26 八月 2019 17:05:05 +0800
Subject: [PATCH] 京东订单修改

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java |   88 ++++++++++++++++++++++++++++++--------------
 1 files changed, 60 insertions(+), 28 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 3e8b365..c5a53c0 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
@@ -28,6 +28,7 @@
 import com.yeshi.fanli.dto.pdd.PDDGoodsResult;
 import com.yeshi.fanli.dto.pdd.PDDSearchFilter;
 import com.yeshi.fanli.entity.accept.AcceptData;
+import com.yeshi.fanli.entity.goods.CommonGoods;
 import com.yeshi.fanli.entity.jd.JDGoods;
 import com.yeshi.fanli.entity.taobao.SearchFilter;
 import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
@@ -51,6 +52,7 @@
 import com.yeshi.fanli.util.ThreadUtil;
 import com.yeshi.fanli.util.Utils;
 import com.yeshi.fanli.util.cache.TaoBaoGoodsCacheUtil;
+import com.yeshi.fanli.util.factory.CommonGoodsFactory;
 import com.yeshi.fanli.util.factory.goods.GoodsDetailVOFactory;
 import com.yeshi.fanli.util.jd.JDApiUtil;
 import com.yeshi.fanli.util.jd.JDUtil;
@@ -119,11 +121,8 @@
 			out.print(JsonUtil.loadFalseResult("鍊间负绌�"));
 			return;
 		}
-
-		if (text.length() > 256) {
-			out.print(JsonUtil.loadFalseResult("鍊艰繃闀�"));
-			return;
-		}
+		// 鍘婚櫎鍓嶅悗绌烘牸
+		text = text.trim();
 
 		TaoBaoGoodsBrief tb = null;
 		String URL_REGEX = "(((http|https)://)|(www\\.))[a-zA-Z0-9\\._-]+\\.[a-zA-Z]{2,6}(:[0-9]{1,4})?(/[a-zA-Z0-9\\&%_\\./-~-]*)?";
@@ -131,17 +130,13 @@
 		Pattern p = Pattern.compile(URL_REGEX);
 		Matcher matcher = p.matcher(text);
 		if (!matcher.find()) {// 涓嶅寘鍚摼鎺�
-			// 鍟嗗搧璇︽儏
-			// 鍙戠幇
-			// 娌℃湁閾炬帴锛屾爣棰樿繃闀夸篃涓嶅鐞�
-			if (text.startsWith("銆�") && text.contains("銆�")) {
-				int end = text.indexOf("銆�");
-				if (end > 2)
-					text = text.substring(1, end);
+			if (text.length() > 256) {
+				out.print(JsonUtil.loadFalseResult("鍊艰繃闀�"));
+				return;
 			}
-
-			if (NumberUtil.isNumeric(text)) {
-				out.println(JsonUtil.loadFalseResult("涓嶆敮鎸佺函鏁板瓧"));
+			String pattern = "^[A-Za-z0-9-]+$";
+			if (Pattern.matches(pattern, text.replace(" ", ""))) {// 鍒犻櫎绌烘牸
+				out.println(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�"));
 				return;
 			}
 
@@ -166,8 +161,16 @@
 			return;
 		}
 
+		CommonGoods commonGoods = null;
 		text = matcher.group();
-		if (text.contains("ju.taobao.com") || text.contains(".juhuasuan.com")) {// 鑱氬垝绠�
+
+		if (text.startsWith("https://a.m.taobao.com/i"))// 娣樺疂璐﹀彿鏈櫥褰曠姸鎬�
+		{
+			text = text.substring("https://a.m.taobao.com/i".length(), text.indexOf(".htm"));
+			if (NumberUtil.isNumeric(text)) {
+				tb = TaoBaoUtil.isAlimama(text);
+			}
+		} else if (text.contains("ju.taobao.com") || text.contains(".juhuasuan.com")) {// 鑱氬垝绠�
 			int index = text.indexOf("item_id");
 			if (index < 0) {
 				out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
@@ -198,26 +201,55 @@
 			}
 		} else {
 			tb = TaoBaoUtil.parsePhoneShareUrlByTB(text);
+			if (tb == null)// 娣樺疂鏄┖鍊�
+			{
+				String jdId = JDUtil.getJDGoodsId(text);
+				if (!StringUtil.isNullOrEmpty(jdId)) {
+					JDGoods goods = JDApiUtil.getGoodsDetail(Long.parseLong(jdId));
+					if (goods != null)
+						commonGoods = CommonGoodsFactory.create(goods);
+				} else {
+					String pddId = PinDuoDuoUtil.getPDDGoodsId(text);
+					if (!StringUtil.isNullOrEmpty(pddId)) {
+						PDDGoodsDetail goods = PinDuoDuoApiUtil.getGoodsDetail(Long.parseLong(pddId));
+						if (goods != null)
+							commonGoods = CommonGoodsFactory.create(goods);
+					}
+				}
+			}
 		}
 
-		if (tb == null) {
+		if (tb == null && commonGoods == null) {
 			out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
 			return;
 		}
+
+		if (tb != null) {
+			commonGoods = new CommonGoods();
+			commonGoods.setPrice(tb.getZkPrice());
+			commonGoods.setTitle(tb.getTitle());
+			commonGoods.setGoodsId(tb.getAuctionId());
+			commonGoods.setGoodsType(Constant.SOURCE_TYPE_TAOBAO);
+			commonGoods.setPicture(tb.getPictUrl());
+		}
+
 		JSONObject data = new JSONObject();
 		JSONObject taoBaoGoodsJSON = new JSONObject();
-		taoBaoGoodsJSON.put("title", tb.getTitle());
-		taoBaoGoodsJSON.put("zkPrice", tb.getZkPrice());
-		taoBaoGoodsJSON.put("id", tb.getAuctionId());
-		taoBaoGoodsJSON.put("goodsType", Constant.SOURCE_TYPE_TAOBAO);
-		taoBaoGoodsJSON.put("url", "http://item.taobao.com/item.htm?id=" + tb.getAuctionId());
-		data.put("goods", taoBaoGoodsJSON);
-		if (!StringUtil.isNullOrEmpty(tb.getPictUrl())) {
-			if (tb.getImgList() == null)
-				tb.setImgList(new ArrayList<>());
-			tb.getImgList().add(0, TbImgUtil.getTBSize220Img(tb.getPictUrl()));
+		taoBaoGoodsJSON.put("title", commonGoods.getTitle());
+		taoBaoGoodsJSON.put("zkPrice", commonGoods.getPrice() + "");
+		taoBaoGoodsJSON.put("id", commonGoods.getGoodsId());
+		taoBaoGoodsJSON.put("goodsType", commonGoods.getGoodsType());
+		if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_TAOBAO) {
+			taoBaoGoodsJSON.put("url", "http://item.taobao.com/item.htm?id=" + commonGoods.getGoodsId());
+		} else if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_JD) {
+			taoBaoGoodsJSON.put("url", String.format("https://item.jd.com/%s.html", commonGoods.getGoodsId() + ""));
+		} else if (commonGoods.getGoodsType() == Constant.SOURCE_TYPE_PDD) {
+			taoBaoGoodsJSON.put("url", "http://yangkeduo.com/goods.html?goods_id=" + commonGoods.getGoodsId());
 		}
-		data.put("imgs", tb.getImgList());
+		data.put("goods", taoBaoGoodsJSON);
+		List<String> picList = new ArrayList<>();
+		picList.add(commonGoods.getPicture());
+		data.put("imgs", picList);
 		JSONObject root = new JSONObject();
 		root.put("type", 1);
 		root.put("data", data);

--
Gitblit v1.8.0