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