From 573c491b4a1ba60e12a5678a01c1546c0077c1ee Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 30 七月 2019 09:07:42 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java |  158 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 158 insertions(+), 0 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
index ffe7db1..cb32794 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/jd/JDUtil.java
@@ -1,14 +1,33 @@
 package com.yeshi.fanli.util.jd;
 
 import java.io.IOException;
+import java.io.UnsupportedEncodingException;
+import java.math.BigDecimal;
+import java.net.URLEncoder;
+import java.util.ArrayList;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
+import org.apache.commons.httpclient.HttpClient;
+import org.apache.commons.httpclient.methods.PostMethod;
 import org.jsoup.Jsoup;
 import org.jsoup.nodes.Document;
 import org.jsoup.nodes.Element;
 import org.jsoup.select.Elements;
 import org.yeshi.utils.HttpUtil;
+
+import com.yeshi.fanli.dto.jd.JDCommissionInfo;
+import com.yeshi.fanli.dto.jd.JDCouponInfo;
+import com.yeshi.fanli.dto.jd.JDSearchFilter;
+import com.yeshi.fanli.dto.jd.JDSearchResult;
+import com.yeshi.fanli.dto.jd.JDShopInfo;
+import com.yeshi.fanli.entity.jd.JDGoods;
+import com.yeshi.fanli.tag.PageEntity;
+import com.yeshi.fanli.util.StringUtil;
+
+import net.sf.json.JSONArray;
+import net.sf.json.JSONObject;
 
 public class JDUtil {
 
@@ -79,4 +98,143 @@
 		System.out.println(result);
 	}
 
+	@SuppressWarnings("deprecation")
+	public static JDSearchResult searchByKey(JDSearchFilter searchFilter) {
+
+		JDSearchResult searchResult = new JDSearchResult();
+
+		List<JDGoods> goodsList = new ArrayList<>();
+		JSONObject params = new JSONObject();
+		params.put("pageNo", searchFilter.getPageNo());
+		params.put("pageSize", searchFilter.getPageSize());
+		params.put("searchUUID", StringUtil.Md5(System.currentTimeMillis() + ""));
+		JSONObject data = new JSONObject();
+		data.put("deliveryType", "0");
+		data.put("hasCoupon", searchFilter.getHasCoupon());
+		data.put("isCare", "0");
+		data.put("isPinGou", "0");
+		data.put("isZY", searchFilter.getIsZY());
+		data.put("key", searchFilter.getKey());
+		data.put("keywordType", "kt1");
+		data.put("lock", "");
+		data.put("orientationFlag", "");
+		data.put("searchType", "st1");
+		params.put("data", data);
+		HttpClient client = new HttpClient();
+		PostMethod pm = new PostMethod("https://union.jd.com/api/goods/search");
+		pm.setRequestHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; rv:11.0) like Gecko");
+		pm.setRequestHeader("Content-Type", "application/json;charset=UTF-8");
+		pm.setRequestHeader("Referer", "https://union.jd.com/proManager/index?pageNo=1&keywords=%E9%9E%8B%E5%AD%90");
+		pm.setRequestBody(params.toString());
+		try {
+			client.executeMethod(pm);
+			String result = pm.getResponseBodyAsString();
+			JSONObject json = JSONObject.fromObject(result);
+			if (json.optInt("code") == 200) {
+				JSONObject pageJson = json.optJSONObject("data").optJSONObject("page");
+				PageEntity entity = new PageEntity(pageJson.optInt("pageNo"), pageJson.optInt("pageSize"),
+						pageJson.optInt("totalCount"));
+				searchResult.setPageEntity(entity);
+
+				if (json.optJSONObject("data") != null) {
+					JSONArray array = json.optJSONObject("data").optJSONArray("unionGoods");
+					if (array != null) {
+						for (int i = 0; i < array.size(); i++) {
+							goodsList.add(parseGoods(array.optJSONArray(i).optJSONObject(0).toString()));
+						}
+					}
+				}
+				json.optJSONObject("data").optJSONArray("unionGoods");
+			}
+
+			System.out.println(result);
+		} catch (Exception e) {
+			e.printStackTrace();
+		}
+
+		searchResult.setGoodsList(goodsList);
+		return searchResult;
+	}
+
+	public static JDGoods getGoodsDetail(Long skuId) {
+		JDSearchFilter sf = new JDSearchFilter();
+		sf.setKey(skuId + "");
+		sf.setPageNo(1);
+		sf.setPageSize(20);
+		JDSearchResult result = searchByKey(sf);
+		if (result != null && result.getGoodsList() != null && result.getGoodsList().size() > 0)
+			return result.getGoodsList().get(0);
+		return null;
+	}
+
+	private static JDGoods parseGoods(String data) {
+		JDGoods goods = new JDGoods();
+		JSONObject json = JSONObject.fromObject(data);
+		goods.setSkuId(json.optLong("skuId"));
+		goods.setSkuName(json.optString("skuName"));
+		JDShopInfo shopInfo = new JDShopInfo();
+		shopInfo.setShopId(json.optInt("shopId"));
+		shopInfo.setShopName(json.optString("shopName"));
+		goods.setShopInfo(shopInfo);
+
+		if (!StringUtil.isNullOrEmpty(json.optString("wlPrice")))
+			goods.setPrice(new BigDecimal(json.optString("wlPrice")));
+		else
+			goods.setPrice(new BigDecimal(json.optString("finalPrice")));
+		goods.setGoodCommentsShare(new BigDecimal(json.optString("goodCommentsShare")));
+		goods.setInOrderCount30Days(json.optLong("inOrderCount30Days"));
+		if (json.optInt("isZY") == 1)
+			goods.setOwner("g");
+		else
+			goods.setOwner("p");
+		goods.setMaterialUrl("http://img14.360buyimg.com/n1/" + json.optString("materialUrl"));
+		JDCommissionInfo commission = new JDCommissionInfo();
+		commission.setCommission(new BigDecimal(json.optString("wlCommission")));
+		commission.setCommissionShare(new BigDecimal(json.optString("wlCommissionRatio")));
+		goods.setCommissionInfo(commission);
+		goods.setGoodCommentsShare(new BigDecimal(json.optString("goodCommentsShare")));
+
+		if (json.optString("hasCoupon") != null && json.optInt("hasCoupon") == 1
+				&& json.optInt("couponRemainCnt") > 0) {
+			// 鏈夊埜
+			JDCouponInfo coupon = new JDCouponInfo();
+			coupon.setDiscount(new BigDecimal(json.optString("couponDiscount")));
+			coupon.setQuota(new BigDecimal(json.optString("couponQuota")));
+			coupon.setLink("https:" + json.optString("couponLink"));
+			goods.setCouponInfo(coupon);
+		} else {
+			// 鏃犲埜
+		}
+		return goods;
+	}
+
+	public static List<String> suggestSearch(String key) {
+		List<String> list = new ArrayList<>();
+		if (StringUtil.isNullOrEmpty(key))
+			return list;
+		String url = null;
+		try {
+			url = String.format(
+					"https://wq.jd.com/bases/searchdropdown/getdropdown?terminal=m&zip=1&key=%s&newjson=1&_=%s&sceneval=2",
+					URLEncoder.encode(key, "UTF-8"), System.currentTimeMillis() + "");
+		} catch (UnsupportedEncodingException e) {
+			e.printStackTrace();
+		}
+
+		if (url == null)
+			return list;
+		try {
+			String result = HttpUtil.get(url);
+			result = result.replace("callback(", "").replace(")", "");
+			JSONArray array = JSONArray.fromObject(result);
+			for (int i = 0; i < array.size(); i++) {
+				String sk = array.optJSONObject(i).optString("key");
+				if (!StringUtil.isNullOrEmpty(sk))
+					list.add(sk);
+			}
+		} catch (Exception e) {
+		}
+		return list;
+	}
+
 }

--
Gitblit v1.8.0