From 744594ef1a2f530fc3e86ea9dc48b62247f79420 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期二, 19 五月 2020 17:13:23 +0800
Subject: [PATCH] 饿了么绘图,添加口碑

---
 fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java |  243 +++++++++++++++++++++++++++++++++++++----------
 1 files changed, 189 insertions(+), 54 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java
index d814855..e9ddfc3 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java
@@ -5,6 +5,7 @@
 import java.net.URLEncoder;
 import java.util.ArrayList;
 import java.util.Collections;
+import java.util.Date;
 import java.util.HashMap;
 import java.util.Iterator;
 import java.util.List;
@@ -18,10 +19,14 @@
 import com.yeshi.fanli.dto.pdd.PDDGoodsDetail;
 import com.yeshi.fanli.dto.pdd.PDDGoodsResult;
 import com.yeshi.fanli.dto.pdd.PDDOrderResult;
+import com.yeshi.fanli.dto.pdd.PDDPromotionUrl;
 import com.yeshi.fanli.dto.pdd.PDDSearchFilter;
+import com.yeshi.fanli.dto.pdd.PDDShopDetail;
+import com.yeshi.fanli.dto.pdd.PDDShopResult;
 import com.yeshi.fanli.entity.pdd.PDDOrder;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.StringUtil;
+import com.yeshi.fanli.util.TimeUtil;
 
 import net.sf.json.JSONArray;
 import net.sf.json.JSONObject;
@@ -70,6 +75,7 @@
 
 	/**
 	 * 澶氬杩涘疂鍟嗗搧鏌ヨ
+	 * 
 	 * @param sf
 	 * @return
 	 */
@@ -94,50 +100,62 @@
 			map.put("keyword", sf.getKw());
 		if (sf.getGoodsIdList() != null)
 			map.put("goods_id_list", "[" + StringUtil.concat(sf.getGoodsIdList(), ",") + "]");
-		
-		
+		if (sf.getMerchantType() != null)
+			map.put("merchant_type", sf.getMerchantType() + "");
 		map.put("pid", PID_FANLI);
 		String result = baseRequest(map);
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("goods_search_response");
 		if (root == null) {
 			return null;
-		} 
-		
+		}
+
 		JSONArray array = root.optJSONArray("goods_list");
 		if (array == null) {
 			return null;
 		}
-		
+
 		Type type = new TypeToken<List<PDDGoodsDetail>>() {
 		}.getType();
-		
+
 		Gson gson = new GsonBuilder().disableHtmlEscaping().create();
 		List<PDDGoodsDetail> goodsList = gson.fromJson(array.toString(), type);
 		int totalCount = root.optInt("total_count");
 		return new PDDGoodsResult(totalCount, goodsList);
 	}
-	
-	
+
+	public static List<PDDGoodsDetail> listGoodsDetail(List<Long> goodsIds) {
+		PDDSearchFilter filter = new PDDSearchFilter();
+		Long[] ids = new Long[goodsIds.size()];
+		goodsIds.toArray(ids);
+		filter.setGoodsIdList(ids);
+		PDDGoodsResult result = searchGoods(filter);
+		if (result != null)
+			return result.getGoodsList();
+		return null;
+	}
+
 	/**
-	 *  杩愯惀棰戦亾鍟嗗搧鏌ヨAPI
+	 * 杩愯惀棰戦亾鍟嗗搧鏌ヨAPI
+	 * 
 	 * @param page
 	 * @param pageSize
-	 * @param channelType  棰戦亾绫诲瀷锛�0, "1.9鍖呴偖", 1, "浠婃棩鐖嗘", 2, "鍝佺墝娓呬粨", 闈炲繀濉� ,榛樿鏄�1
+	 * @param channelType
+	 *            棰戦亾绫诲瀷锛�0, "1.9鍖呴偖", 1, "浠婃棩鐖嗘", 2, "鍝佺墝娓呬粨", 闈炲繀濉� ,榛樿鏄�1
 	 * @return
 	 */
 	public static PDDGoodsResult searchByChannelType(Integer page, Integer pageSize, String channelType) {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.ddk.goods.recommend.get");
-		map.put("offset", (page == null?0:page) + "");
-		map.put("offset", (pageSize == null?Constant.PAGE_SIZE:pageSize) + "");
-		
+		map.put("offset", (page == null ? 0 : page) + "");
+		map.put("offset", (pageSize == null ? Constant.PAGE_SIZE : pageSize) + "");
+
 		if (channelType != null)
 			map.put("channel_type", channelType);
-	
+
 		map.put("pid", PID_FANLI);
 		String result = baseRequest(map);
-		
+
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("goods_basic_detail_response");
 		if (root == null) {
@@ -147,35 +165,34 @@
 		if (array == null) {
 			return null;
 		}
-		
+
 		Type type = new TypeToken<List<PDDGoodsDetail>>() {
 		}.getType();
-		
+
 		Gson gson = new GsonBuilder().disableHtmlEscaping().create();
 		List<PDDGoodsDetail> goodsList = gson.fromJson(array.toString(), type);
 		int totalCount = root.optInt("total");
 		return new PDDGoodsResult(totalCount, goodsList);
 	}
-	
+
 	public static void getGoodsClass() {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.goods.cats.get");
 		map.put("parent_cat_id", "0");
 		String result = baseRequest(map);
-		
+
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("goods_cats_get_response");
 		JSONArray array = root.optJSONArray("goods_cats_list");
 	}
-	
-	
+
 	public static void getThemes(Integer page, Integer pageSize) {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.ddk.theme.list.get");
 		map.put("page", page + "");
-		map.put("page_size", pageSize  + "");
+		map.put("page_size", pageSize + "");
 		String result = baseRequest(map);
-		
+
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("theme_list_get_response");
 		JSONArray array = root.optJSONArray("theme_list");
@@ -186,43 +203,46 @@
 			System.out.println(array.optJSONObject(i).optString("goods_num"));
 			System.out.println("-------------------------------------------");
 		}
-		
+
 		System.out.println(root.optLong("total"));
 	}
-	
-	
+
 	public static void getGoodsOpt() {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.goods.opt.get");
 		map.put("parent_opt_id", "0");
 		String result = baseRequest(map);
-		
+
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("goods_opt_get_response");
 		JSONArray array = root.optJSONArray("goods_opt_list");
 	}
-	
-	
+
 	/**
 	 * 澶氬瀹㈣幏鍙栫垎娆炬帓琛屽晢鍝佹帴鍙�
-	 * @param pid  鎺ㄥ箍浣峣d    (闈炲繀濉�)
-	 * @param page 浠庡灏戜綅缃紑濮嬭姹傦紱榛樿鍊� 锛� 0     (闈炲繀濉�)
-	 * @param pageSize 璇锋眰鏁伴噺锛涢粯璁ゅ�� 锛�20    (闈炲繀濉�)
-	 * @param sortType 1-瀹炴椂鐑攢姒滐紱2-瀹炴椂鏀剁泭姒�    (闈炲繀濉�)
+	 * 
+	 * @param pid
+	 *            鎺ㄥ箍浣峣d (闈炲繀濉�)
+	 * @param page
+	 *            浠庡灏戜綅缃紑濮嬭姹傦紱榛樿鍊� 锛� 0 (闈炲繀濉�)
+	 * @param pageSize
+	 *            璇锋眰鏁伴噺锛涢粯璁ゅ�� 锛�20 (闈炲繀濉�)
+	 * @param sortType
+	 *            1-瀹炴椂鐑攢姒滐紱2-瀹炴椂鏀剁泭姒� (闈炲繀濉�)
 	 * @return
 	 */
 	public static PDDGoodsResult getTopList(String pid, Integer page, Integer pageSize, Integer sortType) {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.ddk.top.goods.list.query");
-		map.put("offset", (page == null? 0: (page-1) * Constant.PAGE_SIZE) +"");
-		map.put("limit", (pageSize == null? Constant.PAGE_SIZE : pageSize) +"");
-		
+		map.put("offset", (page == null ? 0 : (page - 1) * Constant.PAGE_SIZE) + "");
+		map.put("limit", (pageSize == null ? Constant.PAGE_SIZE : pageSize) + "");
+
 		if (!StringUtil.isNullOrEmpty(pid))
 			map.put("p_id", pid + "");
-		
+
 		if (sortType != null)
 			map.put("sort_type", sortType + "");
-	
+
 		String result = baseRequest(map);
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("top_goods_list_get_response");
@@ -233,16 +253,16 @@
 		if (array == null) {
 			return null;
 		}
-		
-		Type type = new TypeToken<List<PDDGoodsDetail>>() {}.getType();
-		
+
+		Type type = new TypeToken<List<PDDGoodsDetail>>() {
+		}.getType();
+
 		Gson gson = new GsonBuilder().disableHtmlEscaping().create();
 		List<PDDGoodsDetail> goodsList = gson.fromJson(array.toString(), type);
-		//int totalCount = root.optInt("total");
+		// int totalCount = root.optInt("total");
 		int totalCount = 400; // 榛樿璁剧疆鎴�400
 		return new PDDGoodsResult(totalCount, goodsList);
 	}
-
 
 	/**
 	 * 鍟嗗搧杞摼
@@ -252,13 +272,14 @@
 	 * @param customParams
 	 * @return
 	 */
-	public static String convert(Long goodsId, String pid, String customParams) {
+	public static PDDPromotionUrl convert(Long goodsId, String pid, String customParams) {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.ddk.goods.promotion.url.generate");
 		map.put("p_id", pid);
 		map.put("multi_group", "true");
 		map.put("generate_weapp_webview", "true");
-//		map.put("generate_weiboapp_webview", "true");
+
+		// map.put("generate_weiboapp_webview", "true");
 		JSONArray array = new JSONArray();
 		array.add(goodsId);
 		map.put("goods_id_list", array.toString());
@@ -273,8 +294,61 @@
 			return null;
 		}
 		JSONArray resultArray = json.optJSONArray("goods_promotion_url_list");
-		if (resultArray != null && resultArray.size() > 0)
-			return resultArray.optJSONObject(0).optString("short_url");
+		if (resultArray != null && resultArray.size() > 0) {
+			Type type = new TypeToken<PDDPromotionUrl>() {
+			}.getType();
+			Gson gson = new GsonBuilder().disableHtmlEscaping().create();
+			return gson.fromJson(resultArray.optJSONObject(0).toString(), type);
+		}
+		return null;
+	}
+
+	/**
+	 * 寰俊灏忕▼搴忚浆閾� @Title: convertWXMP @Description: @param goodsId @param
+	 * pid @param customParams @return PDDPromotionUrl 杩斿洖绫诲瀷 @throws
+	 */
+	public static String convertWXMP(Long goodsId, String pid, String customParams) {
+		Map<String, String> map = new HashMap<>();
+		map.put("type", "pdd.ddk.goods.promotion.url.generate");
+		map.put("p_id", pid);
+		map.put("multi_group", "true");
+		map.put("generate_we_app", "true");
+
+		JSONArray array = new JSONArray();
+		array.add(goodsId);
+		map.put("goods_id_list", array.toString());
+		if (!StringUtil.isNullOrEmpty(customParams)) {
+			map.put("custom_parameters", customParams);
+		}
+
+		String result = baseRequest(map);
+		JSONObject root = JSONObject.fromObject(result);
+		JSONObject json = root.optJSONObject("goods_promotion_url_generate_response");
+		if (json == null) {
+			return null;
+		}
+		JSONArray resultArray = json.optJSONArray("goods_promotion_url_list");
+		if (resultArray != null && resultArray.size() > 0) {
+			JSONObject weApp = resultArray.optJSONObject(0).optJSONObject("we_app_info");
+			if (weApp != null)
+				return weApp.optString("page_path");
+		}
+		return null;
+	}
+
+	/**
+	 * 鍟嗗搧杞摼
+	 * 
+	 * @param goodsId
+	 * @param pid
+	 * @param customParams
+	 * @return
+	 */
+	public static String getPromotionUrl(Long goodsId, String pid, String customParams) {
+		PDDPromotionUrl promotion = convert(goodsId, pid, customParams);
+		if (promotion != null) {
+			return promotion.getShortUrl();
+		}
 		return null;
 	}
 
@@ -302,7 +376,7 @@
 	 *            涓庡紑濮嬫椂闂翠笉寰楀ぇ浜�24灏忔椂
 	 * @return
 	 */
-	public static PDDOrderResult getOrders(int page, int pageSize, long startTime, long endTime) {
+	public static PDDOrderResult getOrdersList(int page, int pageSize, long startTime, long endTime) {
 		Map<String, String> map = new HashMap<>();
 		map.put("type", "pdd.ddk.order.list.increment.get");
 		map.put("start_update_time", startTime / 1000 + "");
@@ -310,6 +384,7 @@
 		map.put("page", page + "");
 		map.put("page_size", pageSize + "");
 		String result = baseRequest(map);
+		System.out.println(result);
 		JSONObject json = JSONObject.fromObject(result);
 		JSONObject root = json.optJSONObject("order_list_get_response");
 		if (root != null) {
@@ -319,6 +394,20 @@
 			}.getType();
 			List<PDDOrder> orderList = new Gson().fromJson(array.toString(), type);
 			return new PDDOrderResult(totalCount, orderList);
+		}
+		return null;
+	}
+
+	public static PDDOrder getOrderDetail(String orderSn) {
+		Map<String, String> map = new HashMap<>();
+		map.put("type", "pdd.ddk.order.detail.get");
+		map.put("order_sn", orderSn);
+		String result = baseRequest(map);
+		System.out.println(result);
+		JSONObject json = JSONObject.fromObject(result);
+		JSONObject root = json.optJSONObject("order_detail_response");
+		if (root != null) {
+			return new Gson().fromJson(root.toString(), PDDOrder.class);
 		}
 		return null;
 	}
@@ -340,12 +429,12 @@
 		if (root == null) {
 			return null;
 		}
-		
+
 		JSONArray resultArray = root.optJSONArray("goods_details");
 		if (resultArray == null) {
 			return null;
 		}
-		
+
 		Type type = new TypeToken<List<PDDGoodsDetail>>() {
 		}.getType();
 		List<PDDGoodsDetail> goodsList = new Gson().fromJson(resultArray.toString(), type);
@@ -353,8 +442,7 @@
 			return goodsList.get(0);
 		return null;
 	}
-	
-	
+
 	/**
 	 * 鑾峰彇鍟嗗搧璇︽儏
 	 * 
@@ -373,11 +461,58 @@
 		JSONObject root = resultJson.optJSONObject("ddk_phrase_generate_response");
 		if (root != null) {
 			array = root.optJSONArray("promotion_phrase_list");
-			JSONObject phraseObject = JSONObject.fromObject( array.get(0));
+			JSONObject phraseObject = JSONObject.fromObject(array.get(0));
 			return phraseObject.optString("phrase");
 		}
-		
+
 		return null;
 	}
 
+	public static Date getSystemTime() {
+		try {
+			Map<String, String> map = new HashMap<>();
+			map.put("type", "pdd.time.get");
+			String result = baseRequest(map);
+			String time = JSONObject.fromObject(result).optJSONObject("time_get_response").optString("time");
+			return new Date(TimeUtil.convertToTimeTemp(time, "yyyy-MM-dd HH:mm:ss"));
+		} catch (Exception e) {
+		}
+		return null;
+	}
+
+	/**
+	 * 鑾峰彇鍟嗗搧璇︽儏
+	 * 
+	 * @param goodsId
+	 */
+	public static PDDShopResult getShopList(Integer page, Long catId) {
+		JSONArray arrayType = new JSONArray();
+		arrayType.add(3);
+
+		Map<String, String> map = new HashMap<>();
+		map.put("type", "pdd.ddk.merchant.list.get");
+		if (catId != null)
+			map.put("cat_id", catId + "");
+		if (page != null)
+			map.put("page_number", page + "");
+
+		if (page != null)
+			map.put("page_number", page + "");
+
+		map.put("merchant_type_list", arrayType.toString());
+
+		String result = baseRequest(map);
+		JSONObject resultJson = JSONObject.fromObject(result);
+		JSONObject root = resultJson.optJSONObject("merchant_list_response");
+		if (root != null) {
+			int totalCount = root.optInt("total");
+
+			JSONArray array = root.optJSONArray("mall_search_info_vo_list");
+			Type type = new TypeToken<List<PDDShopDetail>>() {
+			}.getType();
+			List<PDDShopDetail> listShop = new Gson().fromJson(array.toString(), type);
+			return new PDDShopResult(totalCount, listShop);
+		}
+		return null;
+	}
 }

--
Gitblit v1.8.0