From 788deca1b4a24f8a24e49c24f7d89975a1d74bbe Mon Sep 17 00:00:00 2001
From: admin <2780501319@qq.com>
Date: 星期日, 03 十一月 2019 23:31:25 +0800
Subject: [PATCH] 商城订单退款处理

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java |  569 ++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 447 insertions(+), 122 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 ee7f93d..bde152b 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
@@ -10,16 +10,21 @@
 import java.util.regex.Pattern;
 
 import javax.annotation.Resource;
+import javax.servlet.http.HttpSession;
 
 import org.springframework.core.task.TaskExecutor;
 import org.springframework.stereotype.Controller;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.bind.annotation.RequestMethod;
+import org.yeshi.utils.HttpUtil;
 import org.yeshi.utils.JsonUtil;
+import org.yeshi.utils.NumberUtil;
 import org.yeshi.utils.taobao.TbImgUtil;
 
 import com.google.gson.Gson;
 import com.google.gson.GsonBuilder;
+import com.yeshi.fanli.dto.ConfigParamsDTO;
+import com.yeshi.fanli.dto.douyin.DouYinGoods;
 import com.yeshi.fanli.dto.jd.JDFilter;
 import com.yeshi.fanli.dto.jd.JDSearchFilter;
 import com.yeshi.fanli.dto.jd.JDSearchResult;
@@ -27,29 +32,38 @@
 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;
 import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
 import com.yeshi.fanli.entity.taobao.dataoke.DaTaoKeDetail;
+import com.yeshi.fanli.exception.taobao.TaobaoGoodsDownException;
+import com.yeshi.fanli.exception.user.TokenRecordException;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.config.BusinessSystemService;
 import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.config.SuperHotSearchService;
-import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
 import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
 import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService;
+import com.yeshi.fanli.service.inter.order.config.HongBaoManageService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoShopService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService;
 import com.yeshi.fanli.service.inter.taobao.dataoke.DaTaoKeGoodsDetailService;
 import com.yeshi.fanli.service.inter.user.HistorySearchService;
+import com.yeshi.fanli.service.inter.user.TokenRecordService;
+import com.yeshi.fanli.service.inter.user.integral.IntegralGetService;
 import com.yeshi.fanli.tag.PageEntity;
 import com.yeshi.fanli.util.Constant;
-import com.yeshi.fanli.util.GsonUtil;
+import com.yeshi.fanli.util.DouYinUtil;
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.ThreadUtil;
 import com.yeshi.fanli.util.Utils;
+import com.yeshi.fanli.util.VersionUtil;
+import com.yeshi.fanli.util.annotation.RequestSerializableByKey;
+import com.yeshi.fanli.util.cache.IntegralGetCacheManager;
 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;
@@ -57,8 +71,11 @@
 import com.yeshi.fanli.util.pinduoduo.PinDuoDuoUtil;
 import com.yeshi.fanli.util.taobao.SearchFilterUtil;
 import com.yeshi.fanli.util.taobao.TaoBaoUtil;
+import com.yeshi.fanli.util.taobao.TaoKeApiUtil;
+import com.yeshi.fanli.vo.brand.BrandInfoVO;
 import com.yeshi.fanli.vo.brand.TaoBaoShopVO;
 import com.yeshi.fanli.vo.goods.GoodsDetailVO;
+import com.yeshi.fanli.vo.msg.TokenVO;
 
 import net.sf.json.JSONArray;
 import net.sf.json.JSONObject;
@@ -99,12 +116,19 @@
 
 	@Resource
 	private DaTaoKeGoodsDetailService daTaoKeGoodsDetailService;
-	
+
 	@Resource(name = "taskExecutor")
 	private TaskExecutor executor;
 
-	
-	
+	@Resource
+	private TokenRecordService tokenRecordService;
+
+	@Resource
+	private IntegralGetService integralGetService;
+
+	@Resource
+	private IntegralGetCacheManager integralGetCacheManager;
+
 	/**
 	 * 绮樿创鏉夸俊鎭帹鑽�
 	 * 
@@ -113,16 +137,24 @@
 	 *            鍟嗗搧閾炬帴
 	 * @param out
 	 */
-	@RequestMapping(value = "getNewGoodsInfo", method = RequestMethod.POST)
-	public void getNewGoodsInfo(AcceptData acceptData, String text, PrintWriter out) {
+	@RequestMapping(value = "getRecommendInfo", method = RequestMethod.POST)
+	public void getRecommendInfo(AcceptData acceptData, String text, Long uid, PrintWriter out) {
 		if (StringUtil.isNullOrEmpty(text)) {
 			out.print(JsonUtil.loadFalseResult("鍊间负绌�"));
 			return;
 		}
+		// 鍘婚櫎鍓嶅悗绌烘牸
+		text = text.trim();
 
-		if (text.length() > 256) {
-			out.print(JsonUtil.loadFalseResult("鍊艰繃闀�"));
+		try {
+			TokenVO tokenVO = tokenRecordService.discernToken(text, uid);
+			out.print(JsonUtil.loadTrueResult(tokenVO));
 			return;
+		} catch (TokenRecordException e) {
+			if (e.getCode() == 1001) { // 闇�瑕佺敤鎴风櫥褰�
+				out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg()));
+				return;
+			}
 		}
 
 		TaoBaoGoodsBrief tb = null;
@@ -131,13 +163,14 @@
 		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;
+			}
+			String pattern = "^[A-Za-z0-9-]+$";
+			if (Pattern.matches(pattern, text.replace(" ", ""))) {// 鍒犻櫎绌烘牸
+				out.println(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�"));
+				return;
 			}
 
 			LogHelper.test("鏍规嵁绮樿创鏉挎帹鑽�:" + text);
@@ -147,41 +180,33 @@
 				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));
+			if (analysisTaoToken(acceptData, text, out)) {
 				return;
 			}
-
-			out.print(JsonUtil.loadFalseResult("鏆備笉鏀寔璇ョ被鍨嬶紒"));
+			if (!StringUtil.isNullOrEmpty(TaoBaoUtil.parseSystemTaoToken(text))) {
+				out.print(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�"));
+				return;
+			}
+			JSONObject root = new JSONObject();
+			root.put("type", 2);
+			JSONObject data = new JSONObject();
+			data.put("title", text);
+			root.put("data", data);
+			out.print(JsonUtil.loadTrueResult(root));
 			return;
 		}
 
+		int type = 3;
+		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("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
@@ -197,7 +222,8 @@
 			}
 			tb = TaoBaoUtil.isAlimama(id);
 			if (tb == null) {
-				tb = TaoBaoUtil.parsePhoneTmAndTb(id);
+				type = 4;
+				tb = TaoBaoUtil.getTmallGoodsInfo(id);
 			}
 		} else if (text.contains("http://zmnxbc.com")) { // 鎵嬫満绔ぉ鐚獳PP鍒嗕韩
 			tb = TaoBaoUtil.parsePhoneShareUrlByTM(text);
@@ -208,38 +234,285 @@
 			id = map.get("id").replace("}", "");
 			tb = TaoBaoUtil.isAlimama(id);
 			if (tb == null) {
-				tb = TaoBaoUtil.parsePhoneTmAndTb(id);
+				type = 4;
+				tb = TaoBaoUtil.getTmallGoodsInfo(id);
 			}
+		} else if (text.contains("v.douyin.com")) { // 鎶栭煶
+			analysisDouYin(acceptData, text, out);
+			return;
 		} else {
 			tb = TaoBaoUtil.parsePhoneShareUrlByTB(text);
+
+			if (tb == null) {
+				String goodsId = TaoBaoUtil.getGoodsIdByPhoneShareUrl(text);
+				if (!StringUtil.isNullOrEmpty(goodsId)) {
+					tb = TaoBaoUtil.getTmallGoodsInfo(goodsId);
+					if (tb != null)
+						type = 4;
+				}
+			}
+
+			if (tb == null)// 娣樺疂鏄┖鍊�
+			{
+				String jdId = JDUtil.getJDGoodsId(text);
+				if (!StringUtil.isNullOrEmpty(jdId)) {
+					JDGoods goods = JDApiUtil.getGoodsDetail(Long.parseLong(jdId));
+					if (goods != null) {
+						// 楂樼骇鎺ュ彛 -- 淇℃伅鏇村畬鏁�
+						JDGoods jdGoods = JDApiUtil.queryGoodsDetail(Long.parseLong(jdId));
+						if (jdGoods != null) {
+							commonGoods = CommonGoodsFactory.create(jdGoods);
+						} else {
+							commonGoods = CommonGoodsFactory.create(goods);
+						}
+					} else {
+						type = 4;
+						goods = JDUtil.getSimpleGoodsInfo(jdId);
+						if (goods != null) {
+							commonGoods = new CommonGoods();
+							commonGoods.setTitle(goods.getSkuName());
+							commonGoods.setPicture(goods.getPicUrl());
+						}
+					}
+				} else {
+					String pddId = PinDuoDuoUtil.getPDDGoodsId(text);
+					if (!StringUtil.isNullOrEmpty(pddId)) {
+						PDDGoodsDetail goods = PinDuoDuoApiUtil.getGoodsDetail(Long.parseLong(pddId));
+						if (goods != null) {
+							commonGoods = CommonGoodsFactory.create(goods);
+						} else {
+							type = 4;
+							goods = PinDuoDuoUtil.getPDDGoodsInfo(pddId);
+							if (goods != null) {
+								commonGoods = new CommonGoods();
+								commonGoods.setTitle(goods.getGoodsName());
+								commonGoods.setPicture(goods.getGoodsThumbnailUrl());
+							}
+						}
+					}
+				}
+			}
 		}
 
-		if (tb == null) {
+		if (tb == null && commonGoods == null) {
 			out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
 			return;
 		}
-		JSONObject data = new JSONObject();
-		JSONObject taoBaoGoodsJSON = new JSONObject();
-		taoBaoGoodsJSON.put("title", tb.getTitle());
-		taoBaoGoodsJSON.put("zkPrice", tb.getZkPrice());
-		taoBaoGoodsJSON.put("auctionId", tb.getAuctionId());
-		taoBaoGoodsJSON.put("url", "http://item.taobao.com/item.htm?id=" + tb.getAuctionId());
-		data.put("taoBaoGoodsBrief", taoBaoGoodsJSON);
-		if (!StringUtil.isNullOrEmpty(tb.getPictUrl())) {
-			if (tb.getImgList() == null)
-				tb.setImgList(new ArrayList<>());
-			tb.getImgList().add(0, TbImgUtil.getTBSize220Img(tb.getPictUrl()));
+
+		if (type == 4) {
+			if (!VersionUtil.greaterThan_2_0_1(acceptData.getPlatform(), acceptData.getVersion())) {
+				out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
+				return;
+			}
+
+			JSONObject data = new JSONObject();
+			if (tb != null) {
+				commonGoods = new CommonGoods();
+				commonGoods.setTitle(tb.getTitle());
+				commonGoods.setPicture(tb.getPictUrl());
+			}
+
+			if (StringUtil.isNullOrEmpty(commonGoods.getTitle())
+					|| StringUtil.isNullOrEmpty(commonGoods.getPicture())) {
+				out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
+				return;
+			}
+
+			JSONObject goodsJSON = new JSONObject();
+			goodsJSON.put("title", commonGoods.getTitle());
+			goodsJSON.put("pictUrl", commonGoods.getPicture());
+
+			data.put("type", type);
+			data.put("desc", "璇ュ晢鍝佹棤鎺ㄥ箍淇℃伅");
+			data.put("goods", goodsJSON);
+			out.print(JsonUtil.loadTrueResult(data));
+			return;
 		}
-		data.put("tbImgs", tb.getImgList());
+
+		JSONObject data = new JSONObject();
+		if (VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) {
+			if (tb != null) {
+				TaoBaoGoodsBrief goodsBrief = null;
+				try {
+					goodsBrief = TaoKeApiUtil.searchGoodsDetail(tb.getAuctionId());
+				} catch (TaobaoGoodsDownException e) {
+					e.printStackTrace();
+				}
+				if (goodsBrief == null) {
+					out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
+					return;
+				}
+				commonGoods = CommonGoodsFactory.create(goodsBrief);
+			}
+
+			BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
+			BigDecimal shareRate = hongBaoManageService.getShareRate();
+			Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
+					.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
+			data.put("type", type);
+			data.put("goods",
+					gson.toJson(GoodsDetailVOFactory.convertCommonGoods(commonGoods, new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE))));
+			out.print(JsonUtil.loadTrueResult(data));
+			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 taoBaoGoodsJSON = new JSONObject();
+		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("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);
-
 		out.print(JsonUtil.loadTrueResult(root));
 	}
-	
-	
-	
+
+	/**
+	 * 瑙f瀽鎶栭煶閾炬帴
+	 * 
+	 * @param acceptData
+	 * @param text
+	 * @param out
+	 * @return
+	 */
+	private void analysisDouYin(AcceptData acceptData, String text, PrintWriter out) {
+		String location = HttpUtil.getLocation(text);
+		if (!StringUtil.isNullOrEmpty(location)) {
+			if (location.contains("taobao.com")) { // 娣樺疂鍟嗗搧
+				String realUrl = TaoBaoUtil.getRealUrl(location);
+				if (!StringUtil.isNullOrEmpty(realUrl)) {
+					getRecommendInfo(acceptData, realUrl, null, out);
+					return;
+				}
+			} else if (location.contains("haohuo.jinritemai.com")) { // 鎶栭煶鍟嗗搧
+				DouYinGoods goods = DouYinUtil.getGoodsInfo(location);
+				JSONObject goodsJSON = new JSONObject();
+				goodsJSON.put("title", goods.getName());
+				goodsJSON.put("pictUrl", goods.getImg());
+
+				JSONObject data = new JSONObject();
+				data.put("type", 4);
+				data.put("desc", "璇ュ晢鍝佹棤鎺ㄥ箍淇℃伅");
+				data.put("goods", goodsJSON);
+				out.print(JsonUtil.loadTrueResult(data));
+				return;
+			}
+		}
+		out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
+		return;
+	}
+
+	/**
+	 * 瑙f瀽娣樺彛浠�
+	 * 
+	 * @param acceptData
+	 * @param text
+	 * @param out
+	 * @return
+	 */
+	private boolean analysisTaoToken(AcceptData acceptData, String text, PrintWriter out) {
+		String token = StringUtil.picUpTaoToken(text);
+		if (!StringUtil.isNullOrEmpty(token)) {
+			Long auctionId = TaoKeApiUtil.tokenConvertAuctionId(token);
+			if (auctionId != null) {
+				TaoBaoGoodsBrief tb = null;
+				try {
+					tb = TaoKeApiUtil.getSimpleGoodsInfo(auctionId);
+				} catch (TaobaoGoodsDownException e) {
+					e.printStackTrace();
+				}
+
+				if (tb != null) {
+					if (VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) {
+						TaoBaoGoodsBrief goodsBrief = null;
+						try {
+							goodsBrief = TaoKeApiUtil.searchGoodsDetail(tb.getAuctionId());
+						} catch (TaobaoGoodsDownException e) {
+							e.printStackTrace();
+						}
+
+						if (goodsBrief == null) {
+							out.println(JsonUtil.loadFalseResult("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
+							return false;
+						}
+
+						BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
+						BigDecimal shareRate = hongBaoManageService.getShareRate();
+						Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
+								.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
+
+						JSONObject data = new JSONObject();
+						data.put("type", 3);
+						data.put("goods", gson
+								.toJson(GoodsDetailVOFactory.convertTaoBao(goodsBrief, new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE))));
+						out.print(JsonUtil.loadTrueResult(data));
+						return true;
+					}
+
+					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()));
+					}
+					data.put("imgs", tb.getImgList());
+					JSONObject root = new JSONObject();
+					root.put("type", 1);
+					root.put("data", data);
+					out.print(JsonUtil.loadTrueResult(root));
+					return true;
+				}
+			}
+		}
+		return false;
+	}
+
+	/**
+	 * 鍙d护棰嗗彇
+	 * 
+	 * @param acceptData
+	 * @param kw
+	 * @param goodsType
+	 * @param out
+	 */
+	@RequestSerializableByKey(key = "'tokenReceive-'+#uid")
+	@RequestMapping(value = "tokenReceive", method = RequestMethod.POST)
+	public void tokenReceive(AcceptData acceptData, Long uid, String token, PrintWriter out) {
+		try {
+			String msg = tokenRecordService.receiveToken(token, uid);
+			out.print(JsonUtil.loadTrueResult(msg));
+		} catch (TokenRecordException e) {
+			out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg()));
+		}
+	}
+
 	/**
 	 * 鎼滅储鍊欓�夎瘝
 	 * 
@@ -282,32 +555,52 @@
 	 * @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, Long uid, HttpSession session, 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();
-		
+
+		if (uid != null) {
+			if (page == 1) {
+				integralGetCacheManager.cacheSearchGoods(acceptData.getDevice(), System.currentTimeMillis());
+			} else if (page > 1) {
+				Long lastTime = integralGetCacheManager.getLastSearchTime(acceptData.getDevice());
+				if (lastTime != null && System.currentTimeMillis() - lastTime >= 15 * 1000L) {// 瓒呰繃15s娴忚
+					integralGetCacheManager.clearSearchTime(acceptData.getDevice());
+					ThreadUtil.run(new Runnable() {
+						@Override
+						public void run() {
+							// 澧炲姞閲戝竵
+							integralGetService.addSearchResultScan(uid, key);
+						}
+					});
+				}
+			}
+		}
+
 		executor.execute(new Runnable() {
 			@Override
 			public void run() {
@@ -318,12 +611,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();
@@ -333,20 +625,20 @@
 			return;
 		}
 
-		/*--------- 浜笢鍟嗗搧  -------*/ 
+		/*--------- 浜笢鍟嗗搧  -------*/
 		if (goodsType.intValue() == Constant.SOURCE_TYPE_JD) {
-			searchJDGoods(searchkey, page, filter, order, out);
+			searchJDGoods(acceptData, searchkey, page, filter, order, out);
 			return;
 		}
 
-		/*-------- 鎷煎澶氬晢鍝�  -------*/ 
+		/*-------- 鎷煎澶氬晢鍝�  -------*/
 		if (goodsType.intValue() == Constant.SOURCE_TYPE_PDD) {
-			searchPDDGoods(searchkey, page, filter, order, out);
+			searchPDDGoods(acceptData, searchkey, page, filter, order, out);
 			return;
 		}
 
-		/*-------- 娣樺疂鍟嗗搧  -------*/ 
-		searchTaoBaoGoods(searchkey, page, filter, order, out);
+		/*-------- 娣樺疂鍟嗗搧  -------*/
+		searchTaoBaoGoods(acceptData, searchkey, page, filter, order, out);
 	}
 
 	/**
@@ -360,7 +652,8 @@
 	 * @param endprice
 	 * @return
 	 */
-	private void searchTaoBaoGoods(String key, Integer page, String filter, Integer order, PrintWriter out) {
+	private void searchTaoBaoGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order,
+			PrintWriter out) {
 		SearchFilter sf = new SearchFilter();
 		sf.setKey(SearchFilterUtil.filterSearchContent(key));
 		sf.setPage(page);
@@ -376,25 +669,25 @@
 			} else if (order == 4) { // 杩斿埄姣旈珮鍒颁綆
 				sf.setSort(TaoBaoUtil.SORT_TKRATE_HIGH_TO_LOW);
 			}
-		} 
-		
+		}
+
 		if (!StringUtil.isNullOrEmpty(filter)) {
 			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));
@@ -406,10 +699,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() {
@@ -421,7 +714,7 @@
 				}
 			});
 		}
-		
+
 		List<TaoBaoGoodsBrief> taoBaoGoodsBriefs = null;
 		if (result != null) {
 			taoBaoGoodsBriefs = result.getTaoBaoGoodsBriefs();
@@ -429,7 +722,7 @@
 		if (taoBaoGoodsBriefs == null) {
 			taoBaoGoodsBriefs = new ArrayList<>();
 		}
-	
+
 		if (daTaoKeList != null && daTaoKeList.size() > 0) {
 			try {
 				Collections.reverse(daTaoKeList);
@@ -439,32 +732,45 @@
 			} catch (Exception e) {
 			}
 		}
-		
+
 		List<GoodsDetailVO> list = new ArrayList<GoodsDetailVO>();
 		BigDecimal fanLiRate = hongBaoManageService.getFanLiRate();
 		BigDecimal shareRate = hongBaoManageService.getShareRate();
+	    ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE);
+
 		for (TaoBaoGoodsBrief goods : taoBaoGoodsBriefs) {
-			list.add(GoodsDetailVOFactory.convertTaoBao(goods, null, fanLiRate, shareRate));
+			list.add(GoodsDetailVOFactory.convertTaoBao(goods, paramsDTO));
 		}
 
 		Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
 				.excludeFieldsWithoutExposeAnnotation().create();
-		
+
 		JSONObject data = new JSONObject();
 		data.put("result", gson.toJson(list));
 		data.put("count", result.getTaoBaoHead().getDocsfound());
 
-		if (page == 1) {
-			// 绗竴椤佃繑鍥炲簵閾轰俊鎭�
+		if (page == 1) { // 绗竴椤佃繑鍥炲簵閾轰俊鎭�
 			List<TaoBaoShopVO> listShop = taoBaoShopService.getShopByKeyV2(key);
 			if (listShop != null && listShop.size() > 0 && listShop.get(0).getListGoodsVO() != null
 					&& listShop.get(0).getListGoodsVO().size() > 2) {
-				data.put("shop", JsonUtil.getApiCommonGson().toJson(listShop.get(0)));
+				String platform = acceptData.getPlatform();
+				TaoBaoShopVO taoBaoShop = listShop.get(0);
+				if (("ios".equalsIgnoreCase(platform) && VersionUtil.greaterThan_2_0(platform, acceptData.getVersion()))
+						|| ("android".equalsIgnoreCase(platform)
+								&& VersionUtil.greaterThan_2_0_1(platform, acceptData.getVersion()))) {
+					BrandInfoVO brandInfoVO = new BrandInfoVO();
+					brandInfoVO.setId(taoBaoShop.getId());
+					brandInfoVO.setName(taoBaoShop.getShopName());
+					brandInfoVO.setIcon(taoBaoShop.getShopIcon());
+					brandInfoVO.setListGoods(taoBaoShop.getListGoodsVO());
+					data.put("shop", JsonUtil.getApiCommonGson().toJson(brandInfoVO));
+				} else {
+					data.put("shop", JsonUtil.getApiCommonGson().toJson(taoBaoShop));
+				}
 			}
 		}
 		out.print(JsonUtil.loadTrueResult(data));
 	}
-
 
 	/**
 	 * 浜笢
@@ -477,9 +783,11 @@
 	 * @param endprice
 	 * @return
 	 */
-	private void searchJDGoods(String key, Integer page, String filter, Integer order, PrintWriter out) {
-		
+	private void searchJDGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order,
+			PrintWriter out) {
+
 		JDSearchResult result = null;
+		boolean hasCoupon = false;
 		String way = configService.get("jd_api_search_key");
 		if ("1".equals(way)) {
 			JDFilter filterAPI = new JDFilter();
@@ -511,31 +819,30 @@
 				}
 			}
 
-
 			if (!StringUtil.isNullOrEmpty(filter)) {
 				JSONObject jsonfilter = JSONObject.fromObject(filter);
 				Boolean coupon = jsonfilter.optBoolean("coupon");
 				if (coupon != null && coupon) {
+					hasCoupon = true;
 					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 {
 			// 缃戦〉鐖彇
@@ -572,33 +879,42 @@
 				JSONObject jsonfilter = JSONObject.fromObject(filter);
 				Boolean coupon = jsonfilter.optBoolean("coupon");
 				if (coupon != null && coupon) {
+					hasCoupon = true;
 					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();
@@ -614,10 +930,17 @@
 				BigDecimal shareRate = hongBaoManageService.getShareRate();
 				Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
 						.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
+			    ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE);
+
 				for (JDGoods goods : goodsList) {
-					GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertJDGoods(goods, null, fanLiRate,
-							shareRate);
-					array.add(gson.toJson(goodsDetailVO));
+					GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertJDGoods(goods, paramsDTO);
+					if (hasCoupon) {
+						if (goodsDetailVO.isHasCoupon()) {
+							array.add(gson.toJson(goodsDetailVO));
+						}
+					} else {
+						array.add(gson.toJson(goodsDetailVO));
+					}
 				}
 			}
 		}
@@ -628,7 +951,7 @@
 	}
 
 	/**
-	 * 浜笢
+	 * 鎷煎澶�
 	 * 
 	 * @param kw
 	 * @param page
@@ -638,7 +961,8 @@
 	 * @param endprice
 	 * @return
 	 */
-	private void searchPDDGoods(String key, Integer page, String filter, Integer order, PrintWriter out) {
+	private void searchPDDGoods(AcceptData acceptData, String key, Integer page, String filter, Integer order,
+			PrintWriter out) {
 		PDDSearchFilter pddfilter = new PDDSearchFilter();
 		pddfilter.setKw(SearchFilterUtil.filterSearchContent(key));
 		pddfilter.setPage(page);
@@ -664,14 +988,14 @@
 				break;
 			}
 		}
-		
+
 		if (!StringUtil.isNullOrEmpty(filter)) {
 			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); // 鏄惁鏄搧鐗�
@@ -685,15 +1009,16 @@
 		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();
-		
+			    ConfigParamsDTO paramsDTO = new ConfigParamsDTO(fanLiRate, shareRate, Constant.MAX_REWARD_RATE);
+
 				for (PDDGoodsDetail goods : goodsList) {
-					GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertPDDGoods(goods, null, fanLiRate,
-							shareRate);
-					array.add(GsonUtil.toJsonExpose(goodsDetailVO));
+					GoodsDetailVO goodsDetailVO = GoodsDetailVOFactory.convertPDDGoods(goods, paramsDTO);
+					array.add(gson.toJson(goodsDetailVO));
 				}
 			}
 		}

--
Gitblit v1.8.0