From 6b1a7a75b06eafb0bbf7f20d950384a3fde4c8ef Mon Sep 17 00:00:00 2001
From: yujian <yujian@123.com>
Date: 星期三, 10 七月 2019 17:27:33 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoUtil.java |   58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 58 insertions(+), 0 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoUtil.java b/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoUtil.java
index 4df3382..ea48da6 100644
--- a/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoUtil.java
+++ b/fanli/src/main/java/com/yeshi/fanli/util/pinduoduo/PinDuoDuoUtil.java
@@ -1,11 +1,24 @@
 package com.yeshi.fanli.util.pinduoduo;
 
 import java.math.BigDecimal;
+import java.util.ArrayList;
+import java.util.List;
 
+import javax.script.Invocable;
+import javax.script.ScriptEngine;
+import javax.script.ScriptEngineManager;
+
+import org.jsoup.Jsoup;
+import org.jsoup.nodes.Document;
+import org.jsoup.select.Elements;
 import org.yeshi.utils.BigDecimalUtil;
 
 import com.yeshi.fanli.dto.pdd.PDDGoodsDetail;
 import com.yeshi.fanli.util.MoneyBigDecimalUtil;
+
+import net.sf.json.JSONArray;
+import net.sf.json.JSONObject;
+
 
 public class PinDuoDuoUtil {
 
@@ -80,4 +93,49 @@
 		return salesCountMidea;
 	}
 	
+
+
+
+
+	public static List<String> getDetailImages(Long id) {
+		List<String> imgList = new ArrayList<>();
+		try {
+			Document doc = Jsoup.connect("http://yangkeduo.com/goods.html?goods_id="+id)
+					.userAgent(
+							"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36")
+					.get();
+			Elements els = doc.getElementsByTag("script");
+			for (int i = 0; i < els.size(); i++) {
+				if (els.get(i).html().contains("window.rawData")) {
+					String dataJS = els.get(i).html().replace("window.", "var ");
+					dataJS += "function getData(){return JSON.stringify(rawData);}";
+
+					ScriptEngineManager manager = new ScriptEngineManager();
+					ScriptEngine engine = manager.getEngineByName("javascript");
+					try {
+						engine.eval(dataJS);
+						if (engine instanceof Invocable) {
+							Invocable in = (Invocable) engine;
+							String jsonStr = in.invokeFunction("getData").toString();
+							JSONObject json = JSONObject.fromObject(jsonStr);
+							JSONArray array = json.optJSONObject("store").optJSONObject("initDataObj")
+									.optJSONObject("goods").optJSONArray("detailGallery");
+							for (int j = 0; j < array.size(); j++) {
+								imgList.add("http:" + array.optJSONObject(j).optString("url"));
+							}
+						}
+					} catch (Exception e) {
+						e.printStackTrace();
+					}
+					break;
+				}
+			}
+		} catch (Exception e1) {
+			e1.printStackTrace();
+		}
+
+		return imgList;
+
+	}
+
 }

--
Gitblit v1.8.0