From 11c098089f8c4714188e91032e5a19e8fe94bf96 Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期四, 22 八月 2019 09:26:52 +0800
Subject: [PATCH] Merge branch 'div' of ssh://193.112.35.168:29418/fanli-server into div

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/v2/SearchControllerV2.java |   67 +++++++++++++++++++++++++--------
 1 files changed, 51 insertions(+), 16 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 dbde4ce..8ff80dd 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,12 +10,14 @@
 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.JsonUtil;
+import org.yeshi.utils.NumberUtil;
 import org.yeshi.utils.taobao.TbImgUtil;
 
 import com.google.gson.Gson;
@@ -33,6 +35,7 @@
 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.integral.IntegralGetException;
 import com.yeshi.fanli.exception.taobao.TaobaoGoodsDownException;
 import com.yeshi.fanli.exception.user.TokenRecordException;
 import com.yeshi.fanli.log.LogHelper;
@@ -40,6 +43,7 @@
 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.integral.IntegralGetService;
 import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
 import com.yeshi.fanli.service.inter.lable.TaoKeGoodsService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoShopService;
@@ -109,9 +113,12 @@
 
 	@Resource(name = "taskExecutor")
 	private TaskExecutor executor;
-	
+
 	@Resource
 	private TokenRecordService tokenRecordService;
+
+	@Resource
+	private IntegralGetService integralGetService;
 
 	/**
 	 * 绮樿创鏉夸俊鎭帹鑽�
@@ -129,7 +136,7 @@
 		}
 		// 鍘婚櫎鍓嶅悗绌烘牸
 		text = text.trim();
-		
+
 		try {
 			TokenVO tokenVO = tokenRecordService.discernToken(text, uid);
 			out.print(JsonUtil.loadTrueResult(tokenVO));
@@ -140,7 +147,6 @@
 				return;
 			}
 		}
-
 
 		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\\&%_\\./-~-]*)?";
@@ -153,7 +159,7 @@
 				return;
 			}
 			String pattern = "^[A-Za-z0-9-]+$";
-			if (Pattern.matches(pattern, text.replace(" ", ""))) {//鍒犻櫎绌烘牸
+			if (Pattern.matches(pattern, text.replace(" ", ""))) {// 鍒犻櫎绌烘牸
 				out.println(JsonUtil.loadFalseResult("涓嶆敮鎸佹帹鑽�"));
 				return;
 			}
@@ -181,7 +187,14 @@
 
 		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("鏆傛湭鎵惧埌璇ュ晢鍝侊紝璇风◢鍚庡啀璇曪紒"));
@@ -235,10 +248,9 @@
 			return;
 		}
 
-
 		JSONObject data = new JSONObject();
-		
-		if(VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) {
+
+		if (VersionUtil.greaterThan_1_6_5(acceptData.getPlatform(), acceptData.getVersion())) {
 			if (tb != null) {
 				TaoBaoGoodsBrief goodsBrief = null;
 				try {
@@ -257,11 +269,12 @@
 			Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
 					.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
 			data.put("type", 3);
-			data.put("goods", gson.toJson(GoodsDetailVOFactory.convertCommonGoods(commonGoods, null, fanLiRate, shareRate)));
+			data.put("goods",
+					gson.toJson(GoodsDetailVOFactory.convertCommonGoods(commonGoods, null, fanLiRate, shareRate)));
 			out.print(JsonUtil.loadTrueResult(data));
 			return;
 		}
-		
+
 		if (tb != null) {
 			commonGoods = new CommonGoods();
 			commonGoods.setPrice(tb.getZkPrice());
@@ -270,7 +283,7 @@
 			commonGoods.setGoodsType(Constant.SOURCE_TYPE_TAOBAO);
 			commonGoods.setPicture(tb.getPictUrl());
 		}
-		
+
 		JSONObject taoBaoGoodsJSON = new JSONObject();
 		taoBaoGoodsJSON.put("title", commonGoods.getTitle());
 		taoBaoGoodsJSON.put("zkPrice", commonGoods.getPrice() + "");
@@ -331,9 +344,9 @@
 		return false;
 	}
 
-	
 	/**
 	 * 鍙d护棰嗗彇
+	 * 
 	 * @param acceptData
 	 * @param kw
 	 * @param goodsType
@@ -348,9 +361,7 @@
 			out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg()));
 		}
 	}
-	
-	
-	
+
 	/**
 	 * 鎼滅储鍊欓�夎瘝
 	 * 
@@ -403,7 +414,7 @@
 	 */
 	@RequestMapping(value = "searchGoods")
 	public void searchGoods(AcceptData acceptData, Integer goodsType, String key, Integer page, String filter,
-			Integer order, PrintWriter out) {
+			Integer order, Long uid, HttpSession session, PrintWriter out) {
 		if (goodsType == null || goodsType < 1 || goodsType > 3) {
 			out.print(JsonUtil.loadFalseResult(1, "璇蜂紶閫掓纭钩鍙板弬鏁�"));
 			return;
@@ -420,6 +431,30 @@
 		}
 		final String searchkey = key.trim();
 
+		if (uid != null) {
+			if (page == 1) {
+				session.setAttribute("searchFirstTime", System.currentTimeMillis());
+			} else if (page == 2) {
+				Long lastTime = (Long) session.getAttribute("searchFirstTime");
+				if (lastTime != null && System.currentTimeMillis() - lastTime >= 15 * 1000L) {// 瓒呰繃15s娴忚
+				
+					ThreadUtil.run(new Runnable() {
+
+						@Override
+						public void run() {
+							try {
+								// 澧炲姞閲戝竵
+								integralGetService.addSearchResultScan(uid,key);
+							} catch (IntegralGetException e) {
+								e.printStackTrace();
+							}
+						}
+					});
+
+				}
+			}
+		}
+
 		executor.execute(new Runnable() {
 			@Override
 			public void run() {

--
Gitblit v1.8.0