Skip to content

A lightweight web crawler framework.(Java爬虫框架)

License

Notifications You must be signed in to change notification settings

bfyxzls/xxl-crawler

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

XXL-CRAWLER

XXL-CRAWLER, a lightweight web crawler framework.
-- Home Page --

Introduction

XXL-CRAWLER is a lightweight web crawler framework. A line of code to develop a multi-threaded crawler, fully annotated way to collect page data to Java objects, with "multi-threaded, fully annotated, JS rendering, proxy, distributed extension" and other features;

XXL-CRAWLER 是一个轻量级Java爬虫框架。一行代码开发一个多线程爬虫,全注解方式采集页面数据至Java对象,拥有"多线程、全注解、JS渲染、代理、分布式扩展"等特性;

Documentation

Features

  • 1、简洁:API直观简洁,可快速上手;
  • 2、轻量级:底层实现仅强依赖jsoup,简洁高效;
  • 3、模块化:模块化的结构设计,可轻松扩展;
  • 4、全注解:支持通过注解提取页面数据,高效映射页面数据到PageVO对象,底层自动完成PageVO对象的数据抽取和封装返回;单个页面支持抽取一个或多个PageVO;
  • 5、多线程:线程池方式运行,提高采集效率;
  • 6、扩散全站:支持以现有URL为起点扩散爬取整站;
  • 7、JS渲染:通过扩展 "PageLoader" 模块,支持采集JS动态渲染数据。原生提供 Jsoup(非JS渲染,速度更快)、Selenium+ChromeDriver(JS渲染,兼容性高) 等多种实现,支持自由扩展其他实现;
  • 8、代理IP:对抗反采集策略规则WAF;
  • 9、动态代理:支持运行时动态调整代理池,以及自定义代理池路由策略;
  • 10、失败重试:请求失败后重试,并支持设置重试次数;
  • 11、异步:支持同步、异步两种方式运行;
  • 12、幂等去重:防止重复爬取;
  • 13、URL扩散过滤:支持设置页面白名单正则,过滤URL;
  • 14、分布式支持:通过扩展 "RunUrlPool" 模块,并结合Redis或DB共享运行数据可实现分布式。默认提供LocalRunUrlPool单机版爬虫;
  • 15、自定义请求信息,如:请求参数、Cookie、Header、UserAgent轮询、Referrer等;
  • 16、动态参数:支持运行时动态调整请求参数;
  • 17、超时控制:支持设置爬虫请求的超时时间;
  • 18、主动停顿:爬虫线程处理完页面之后进行主动停顿,避免过于频繁被拦截;

Example code

注意:仅供学习测试使用,如有侵犯请联系删除

如下测试代码可以前往仓库查看:测试代码目录

序号 爬虫名称 功能描述 测试用例代码文件
1 Gitee高星项目数据爬虫【页面提取数据】 一行代码启动多线程爬虫,分页方式扩散爬取“Gitee开源项目列表”,通过“注解式”自动提取页面数据,封装成PageVo输出; XxlCrawlerTest01
2 Gitee页面下载爬虫【页面下载】 爬取“Gitee开源项目列表”,获取相关页面html原始数据,下载本地生成html文件; XxlCrawlerTest02
3 网易图片下载爬虫【图片下载】 爬取“网易新闻文章图片”,下载图片文件至本地; XxlCrawlerTest03
4 百度新闻爬虫【接口提取数据】 爬取非Web页面,本案例为JSON接口,直接输出响应数据 XxlCrawlerTest04
5 电商商品价格爬虫【JS渲染方式;Selenium集成】 爬虫获取电商商品价格,由于价格异步渲染;该方案使用 Selenium + ChromeDriver 方式JS渲染,模拟浏览器行为采集数据; XxlCrawlerTest05
6 代理方式爬取数据【Proxy代理方式】 爬取目标页面数据,通过代理进行;可突破访问限制、保障数据安全; XxlCrawlerTest06
7 集群方式爬取数据【Redis集群方式】 爬取目标页面数据,通过集群方式进行;集群中多个XxlCrawler共享RunUrlPool,协同扩散URL并消费待采集任务,提升采集效率。 XxlCrawlerTest07

Communication

Contributing

Contributions are welcome! Open a pull request to fix a bug, or open an Issue to discuss a new feature or change.

欢迎参与项目贡献!比如提交PR修复一个bug,或者新建 Issue 讨论新特性或者变更。

接入登记

更多接入的公司,欢迎在 登记地址 登记,登记仅仅为了产品推广。

Copyright and License

This product is open source and free, and will continue to provide free community technical support. Individual or enterprise users are free to access and use.

  • Licensed under the Apache License, Version 2.0.
  • Copyright (c) 2015-present, xuxueli.

产品开源免费,并且将持续提供免费的社区技术支持。个人或企业内部可自由的接入和使用。

Donate

No matter how much the amount is enough to express your thought, thank you very much :) To donate

无论金额多少都足够表达您这份心意,非常感谢 :) 前往捐赠

About

A lightweight web crawler framework.(Java爬虫框架)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%