From e75b0d79535a6bcd147cca4a54632b70b42afdb9 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期六, 29 五月 2021 18:10:18 +0800
Subject: [PATCH] 特价完善

---
 fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoApiUtil.java |   56 ++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 38 insertions(+), 18 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 e97b937..d73297c 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
@@ -6,6 +6,7 @@
 import java.util.*;
 
 import com.yeshi.fanli.exception.pdd.PDDApiException;
+import com.yeshi.fanli.vo.pdd.PDDConvertLinkResultVO;
 import org.yeshi.utils.HttpUtil;
 
 import com.google.gson.Gson;
@@ -27,9 +28,11 @@
 import net.sf.json.JSONObject;
 
 public class PinDuoDuoApiUtil {
-    public final static String PID_FANLI = "8590899_72067894";
-    public final static String PID_SHARE = "8590899_72067895";
-    public final static String PID_COUPON = "8590899_102657575";
+//    public final static String PID_FANLI = "8590899_72067894";
+//    public final static String PID_SHARE = "8590899_72067895";
+//    public final static String PID_COUPON = "8590899_102657575";
+
+    public final static String PID_DEFAULT = "8590899_72067894";
 
     private final static String CLIENT_ID = "9f6ee5ebd3b94c2080c4d51c2427e9fa";
     private final static String CLIENT_SECRET = "95e1f1904385664bf4b87d4b34de12f9f31c505d";
@@ -104,7 +107,7 @@
             map.put("range_list", gson.toJson(sf.getRangeList()).toString());
         }
 
-        map.put("pid", PID_FANLI);
+        map.put("pid", PID_DEFAULT);
         String result = baseRequest(map);
         System.out.println(result);
         JSONObject json = JSONObject.fromObject(result);
@@ -167,7 +170,7 @@
             map.put("activity_tags", JSONArray.fromObject(Arrays.asList(activityTags)).toString());
         }
 
-        map.put("pid", PID_FANLI);
+        map.put("pid", PID_DEFAULT);
         String result = baseRequest(map);
 
         JSONObject json = JSONObject.fromObject(result);
@@ -282,7 +285,7 @@
      * @param customParams
      * @return
      */
-    public static PDDPromotionUrl convert(String goodsSign, String pid, String customParams, boolean withAuthLink) {
+    public static PDDConvertLinkResultVO convert(String goodsSign, String pid, String customParams, boolean withAuthLink) {
         Map<String, String> map = new HashMap<>();
         map.put("type", "pdd.ddk.goods.promotion.url.generate");
         map.put("p_id", pid);
@@ -311,7 +314,7 @@
         }
         JSONArray resultArray = json.optJSONArray("goods_promotion_url_list");
         if (resultArray != null && resultArray.size() > 0) {
-            Type type = new TypeToken<PDDPromotionUrl>() {
+            Type type = new TypeToken<PDDConvertLinkResultVO>() {
             }.getType();
             Gson gson = new GsonBuilder().disableHtmlEscaping().create();
             return gson.fromJson(resultArray.optJSONObject(0).toString(), type);
@@ -373,9 +376,9 @@
      * @return
      */
     public static String getPromotionUrl(String goodsSign, String pid, String customParams) {
-        PDDPromotionUrl promotion = convert(goodsSign, pid, customParams, false);
+        PDDConvertLinkResultVO promotion = convert(goodsSign, pid, customParams, false);
         if (promotion != null) {
-            return promotion.getShortUrl();
+            return promotion.getShort_url();
         }
         return null;
     }
@@ -444,7 +447,7 @@
      */
     public static PDDGoodsDetail getGoodsDetail(Long goodsId) {
         try {
-            return getGoodsDetail(goodsId, PID_FANLI, "437032");
+            return getGoodsDetail(goodsId, PID_DEFAULT, "437032");
         } catch (PDDApiException e) {
             e.printStackTrace();
         }
@@ -512,7 +515,7 @@
         Map<String, String> map = new HashMap<>();
         map.put("type", "pdd.ddk.phrase.generate");
         map.put("goods_id_list", array.toString());
-        map.put("p_id", PID_FANLI);
+        map.put("p_id", PID_DEFAULT);
         String result = baseRequest(map);
         JSONObject resultJson = JSONObject.fromObject(result);
         JSONObject root = resultJson.optJSONObject("ddk_phrase_generate_response");
@@ -594,23 +597,40 @@
     }
 
 
-    public static String getAuthLink(String pid, String customParameters) {
+    /**
+     * 鐢熸垚鎺堟潈閾炬帴
+     *
+     * @param pid
+     * @param customParameters
+     * @return
+     */
+    public static PDDConvertLinkResultVO getAuthLink(String pid, String customParameters) {
         Map<String, String> map = new HashMap<>();
         map.put("type", "pdd.ddk.rp.prom.url.generate");
         map.put("channel_type", 10 + "");
+        map.put("generate_we_app", true + "");
         map.put("custom_parameters", customParameters);
         map.put("p_id_list", "[\"" + pid + "\"]");
         String result = baseRequest(map);
+        System.out.println(result);
         JSONObject resultJson = JSONObject.fromObject(result);
         JSONArray array = resultJson.optJSONObject("rp_promotion_url_generate_response").optJSONArray("url_list");
         if (array != null && array.size() > 0) {
-            JSONObject item = array.optJSONObject(0);
-            String url = item.optString("url");
-            if (StringUtil.isNullOrEmpty(url)) {
-                url = item.optString("mobile_url");
-            }
-            return url;
+            Type type = new TypeToken<List<PDDConvertLinkResultVO>>() {
+            }.getType();
+            List<PDDConvertLinkResultVO> list = new Gson().fromJson(array.toString(), type);
+            return list.get(0);
         }
         return null;
     }
+
+    public static void main(String[] args) {
+//        PDDConvertLinkResultVO vo = getAuthLink(PID_SHARE, PinDuoDuoUtil.getCustomParams(437032l));
+//
+//        System.out.println(vo);
+        PDDGoodsDetail goods = PinDuoDuoApiUtil.getGoodsDetail(227873724698L);
+
+
+        PinDuoDuoApiUtil.convert(goods.getGoodsSign(), PID_DEFAULT + "","437032", false);
+    }
 }

--
Gitblit v1.8.0