java 爬取京东商品详细信息 价格

java 爬取京东商品详细信息 价格

你好! 这是你第一次使用 **Markdown编辑器** 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。
获取图中的价格,因为京东的价格有反扒机制,价格通过js加载的,直接通过页面标签是获取不到的,所以我们要去要相应的js。
http://p.3.cn/prices/mgets?skuIds=J_
通过发现,这个链接就是查询价格的链接,J_后面跟的就是商品的id,京东商品的id很好找,就是链接中的id:在这里插入图片描述

代码实现

 <dependency>
	<groupId>org.jsoup</groupId>
	<artifactId>jsoup</artifactId>
	<version>1.11.2</version>
</dependency>
public static String sendGet(String url, String param) {
        String result = "";
        String urlName = url + "?" + param;
        try {
            URL realURL = new URL(urlName);
            URLConnection conn = realURL.openConnection();
            conn.setRequestProperty("accept", "*/*");
            conn.setRequestProperty("connection", "Keep-Alive");
            conn.setRequestProperty("user-agent", "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.106 Safari/537.36");
            conn.connect();
            BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "utf-8"));
            String line;
            while ((line = in.readLine()) != null) {
                result += "\n" + line;
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
        return result;
    }
	public static void main(String[] args) throws Exception {
        String url = "https://item.jd.com/65590733400.html";
        String skuId = Pattern.compile("[^0-9]").matcher(url).replaceAll("").trim();
        String sendRecvGet =sendGet("http://p.3.cn/prices/get","skuid="+skuId);
        JSONArray dataArray = new JSONArray(sendRecvGet.toString());
        JSONObject dataJsonObj = dataArray.getJSONObject(0);
        //提取价格
        Object priceStr = dataJsonObj.get("p");
        System.out.println("价格:"+priceStr);
	        
        
    }

sendGet方法主要是为了防止爬取的时候被京东给拦截,所以用这个方法模拟浏览器发送get请求。

结果

在这里插入图片描述
其他信息比如名称、分类、品牌、图片等就很简单了,直接从页面通过相应的标签获取就行了。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值