百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

网络爬虫知识 day04 网络爬虫知识点简单总结

suiw9 2024-10-29 16:42 27 浏览 0 评论

一、封装HttpClient

我们需要经常使用HttpClient,所以需要进行封装,方便使用

@Component

public class HttpUtils {


private PoolingHttpClientConnectionManager cm;


public HttpUtils() {

this.cm = new PoolingHttpClientConnectionManager();


// 设置最大连接数

cm.setMaxTotal(200);


// 设置每个主机的并发数

cm.setDefaultMaxPerRoute(20);

}


//获取内容

public String getHtml(String url) {

// 获取HttpClient对象

CloseableHttpClient httpClient = HttpClients.custom().setConnectionManager(cm).build();


// 声明httpGet请求对象

HttpGet httpGet = new HttpGet(url);

// 设置请求参数RequestConfig

httpGet.setConfig(this.getConfig());


CloseableHttpResponse response = null;

try {

// 使用HttpClient发起请求,返回response

response = httpClient.execute(httpGet);

// 解析response返回数据

if (response.getStatusLine().getStatusCode() == 200) {

String html = "";


// 如果response。getEntity获取的结果是空,在执行EntityUtils.toString会报错

// 需要对Entity进行非空的判断

if (response.getEntity() != null) {

html = EntityUtils.toString(response.getEntity(), "UTF-8");

}


return html;

}


} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if (response != null) {

// 关闭连接

response.close();

}

// 不能关闭,现在使用的是连接管理器

// httpClient.close();

} catch (Exception e) {

e.printStackTrace();

}

}


return null;

}

//获取图片

public String getImage(String url) {

// 获取HttpClient对象

CloseableHttpClient httpClient = HttpClients.custom().setConnectionManager(cm).build();


// 声明httpGet请求对象

HttpGet httpGet = new HttpGet(url);

// 设置请求参数RequestConfig

httpGet.setConfig(this.getConfig());


CloseableHttpResponse response = null;

try {

// 使用HttpClient发起请求,返回response

response = httpClient.execute(httpGet);

// 解析response下载图片

if (response.getStatusLine().getStatusCode() == 200) {

// 获取文件类型

String extName = url.substring(url.lastIndexOf("."));

// 使用uuid生成图片名

String imageName = UUID.randomUUID().toString() + extName;


// 声明输出的文件

OutputStream outstream = new FileOutputStream(new File("D:/images/" + imageName));

// 使用响应体输出文件

response.getEntity().writeTo(outstream);


// 返回生成的图片名

return imageName;

}


} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if (response != null) {

// 关闭连接

response.close();

}

// 不能关闭,现在使用的是连接管理器

// httpClient.close();

} catch (Exception e) {

e.printStackTrace();

}

}


return null;

}


//获取请求参数对象

private RequestConfig getConfig() {

RequestConfig config = RequestConfig.custom().setConnectTimeout(1000)// 设置创建连接的超时时间

.setConnectionRequestTimeout(500) // 设置获取连接的超时时间

.setSocketTimeout(10000) // 设置连接的超时时间

.build();


return config;

}


}


二、实现数据抓取

使用定时任务,可以定时抓取最新的数据

@Component

public class ItemTask {


@Autowired

private HttpUtils httpUtils;

@Autowired

private ItemService itemService;


public static final ObjectMapper MAPPER = new ObjectMapper();



//设置定时任务执行完成后,再间隔100秒执行一次

@Scheduled(fixedDelay = 1000 * 100)

public void process() throws Exception {

//分析页面发现访问的地址,页码page从1开始,下一页oage加2

String url = "https://search.jd.com/Search?keyword=%E6%89%8B%E6%9C%BA&enc=utf-8&qrst=1&rt=1&stop=1&vt=2&cid2=653&cid3=655&s=5760&click=0&page=";


//遍历执行,获取所有的数据

for (int i = 1; i < 10; i = i + 2) {

//发起请求进行访问,获取页面数据,先访问第一页

String html = this.httpUtils.getHtml(url + i);


//解析页面数据,保存数据到数据库中

this.parseHtml(html);


}

System.out.println("执行完成");

}



//解析页面,并把数据保存到数据库中

private void parseHtml(String html) throws Exception {

//使用jsoup解析页面

Document document = Jsoup.parse(html);


//获取商品数据

Elements spus = document.select("div#J_goodsList > ul > li");


//遍历商品spu数据

for (Element spuEle : spus) {

//获取商品spu

Long spuId = Long.parseLong(spuEle.attr("data-spu"));


//获取商品sku数据

Elements skus = spuEle.select("li.ps-item img");

for (Element skuEle : skus) {

//获取商品sku

Long skuId = Long.parseLong(skuEle.attr("data-sku"));


//判断商品是否被抓取过,可以根据sku判断

Item param = new Item();

param.setSku(skuId);

List<Item> list = this.itemService.findAll(param);

//判断是否查询到结果

if (list.size() > 0) {

//如果有结果,表示商品已下载,进行下一次遍历

continue;

}


//保存商品数据,声明商品对象

Item item = new Item();


//商品spu

item.setSpu(spuId);

//商品sku

item.setSku(skuId);

//商品url地址

item.setUrl("https://item.jd.com/" + skuId + ".html");

//创建时间

item.setCreated(new Date());

//修改时间

item.setUpdated(item.getCreated());



//获取商品标题

String itemHtml = this.httpUtils.getHtml(item.getUrl());

String title = Jsoup.parse(itemHtml).select("div.sku-name").text();

item.setTitle(title);


//获取商品价格

String priceUrl = "https://p.3.cn/prices/mgets?skuIds=J_"+skuId;

String priceJson = this.httpUtils.getHtml(priceUrl);

//解析json数据获取商品价格

double price = MAPPER.readTree(priceJson).get(0).get("p").asDouble();

item.setPrice(price);


//获取图片地址

String pic = "https:" + skuEle.attr("data-lazy-img").replace("/n9/","/n1/");

System.out.println(pic);

//下载图片

String picName = this.httpUtils.getImage(pic);

item.setPic(picName);


//保存商品数据

this.itemService.save(item);

}

}

}

}

相关推荐

5款Syslog集中系统日志常用工具对比推荐

一、为何要集中管理Syslog?Syslog由Linux/Unix系统及其他网络设备生成,广泛分布于整个网络。因其包含关键信息,可用于识别网络中的恶意活动,所以必须对其进行持续监控。将Sys...

跨平台、多数据库支持的开源数据库管理工具——DBeaver

简介今天给大家推荐一个开源的数据库管理工具——DBeaver。它支持多种数据库系统,包括Mysql、Oracle、PostgreSQL、SLQLite、SQLServer等。DBeaver的界面友好...

强烈推荐!数据库管理工具:Navicat Premium 16.3.2 (64位)

NavicatPremium,一款集数据迁移、数据库管理、SQL/查询编辑、智能设计、高效协作于一体的全能数据库开发工具。无论你是MySQL、MariaDB、MongoDB、SQLServer、O...

3 年 Java 程序员还玩不转 MongoDB,网友:失望

一、什么场景使用MongoDB?...

拯救MongoDB管理员的GUI工具大赏:从菜鸟到极客的生存指南

作为一名在NoSQL丛林中披荆斩棘的数据猎人,没有比GUI工具更称手的瑞士军刀了。本文将带你围观五款主流MongoDB管理神器的特性与暗坑,附赠精准到扎心的吐槽指南一、MongoDBCompass:...

mongodb/redis/neo4j 如何自己打造一个 web 数据库可视化客户端?

前言最近在做neo4j相关的同步处理,因为产线的可视化工具短暂不可用,发现写起来各种脚本非常麻烦。...

solidworks使用心得,纯干货!建议大家收藏

SolidWorks常见问题...

统一规约-关乎数字化的真正实现(规范统一性)

尽管数字化转型的浪潮如此深入人心,但是,对于OPCUA和TSN的了解却又甚少,这难免让人质疑其可实现性,因为,如果缺乏统一的语义互操作规范,以及更为具有广泛适用的网络与通信,则数字化实际上几乎难以具...

Elasticsearch节点角色配置详解(Node)

本篇文章将介绍如下内容:节点角色简介...

产前母婴用品分享 篇一:我的母婴购物清单及单品推荐

作者:DaisyH8746在张大妈上已经混迹很久了,有事没事看看“什么值得买”已渐渐成了一种生活习惯,然而却从来没有想过自己要写篇文章发布上来,直到由于我产前功课做得“太过认真”(认真到都有点过了,...

比任何人都光彩照人的假期!水润、紧致的肌肤护理程序

图片来源:谜尚愉快的假期临近了。身心振奋的休假季节。但是不能因为这种心情而失去珍贵的东西,那就是皮肤健康。炙热的阳光和强烈的紫外线是使我们皮肤老化的主犯。因此,如果怀着快乐的心情对皮肤置之不理,就会使...

Arm发布Armv9边缘AI计算平台,支持运行超10亿参数端侧AI模型

中关村在线2月27日消息,Arm正式发布Armv9边缘人工智能(AI)计算平台。据悉,该平台以全新的ArmCortex-A320CPU和领先的边缘AI加速器ArmEthos-U85NPU为核心...

柔性——面向大规模定制生产的数字化实现的基本特征

大规模定制生产模式的核心是柔性,尤其是体现在其对定制的要求方面。既然是定制,并且是大规模的定制,对于制造系统的柔性以及借助于数字化手段实现的柔性,就提出了更高的要求。面向大规模定制生产的数字化业务管控...

创建PLC内部标准——企业前进的道路

作者:FrankBurger...

标准化编程之 ----------- 西门子LPMLV30测试总结

PackML乃是由OMAC开发且被ISA所采用的自动化标准TR88.00.02,能够更为便捷地传输与检索一致的机器数据。PackML的主要宗旨在于于整个工厂车间倡导通用的“外观和感觉”,...

取消回复欢迎 发表评论: