一、介绍

WebMagic是一个简单灵活的Java爬虫框架。基于WebMagic,你可以快速开发出一个高效、易维护的爬虫。

二、如何学习

1.查看官网

2.跑通hello world示例(具体可以参考官网,也可以参考博客)

我下面写的单元测试案例,可作为Hello World示例。

注意需要导入Maven依赖:

us.codecraft

webmagic-core

0.7.3

us.codecraft

webmagic-extension

0.7.3

3.带着一个目的

说说我的目的,最近我开发的博客系统,其中有个导入第三方博客的插件,这个插件比较简单就是一个搜索框,在对应的搜索框里面填写URL,点击搜索即可导入到自己的博客。

以导入博客园单篇文章为例:

下面是我的源代码(单篇文章导入,我已经将其封装成一个工具类):

import cn.hutool.core.date.DateUtil;

import com.blog.springboot.dto.CnBlogModelDTO;

import com.blog.springboot.entity.Posts;

import com.blog.springboot.service.PostsService;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Component;

import us.codecraft.webmagic.Page;

import us.codecraft.webmagic.Site;

import us.codecraft.webmagic.Spider;

import us.codecraft.webmagic.pipeline.ConsolePipeline;

import us.codecraft.webmagic.processor.PageProcessor;

import us.codecraft.webmagic.selector.Selectable;

import javax.annotation.PostConstruct;

/**

* 导入博客园文章工具类

*/

@Component

public class WebMagicCnBlogUtils implements PageProcessor {

@Autowired

private PostsService postService;

public static WebMagicCnBlogUtils magicCnBlogUtils;

@PostConstruct

public void init() {

magicCnBlogUtils = this;

magicCnBlogUtils.postService = this.postService;

}

private Site site = Site.me()

.setDomain("https://www.cnblogs.com/")

.setSleepTime(1000)

.setUserAgent("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36");

@Override

public void process(Page page) {

Selectable obj = page.getHtml().xpath("//div[@class='post']");

Selectable title = obj.xpath("//h1[@class='postTitle']//a");

Selectable content = obj.xpath("//div[@class='blogpost-body']");

System.out.println("title:" + title.replace("]*>", ""));

System.out.println("content:" + content);

CnBlogModelDTO blog = new CnBlogModelDTO();

blog.setTitle(title.toString());

blog.setContent(content.toString());

Posts post = new Posts();

String date = DateUtil.date().toString();

post.setPostAuthor(1L);

post.setPostTitle(title.replace("]*>", "").toString());

post.setPostContent(content.toString());

post.setPostExcerpt(content.replace("]*>", "").toString());

post.setPostDate(date);

post.setPostDate(date);

post.setPostModified(date);

boolean importPost = magicCnBlogUtils.postService.insert(post);

if (importPost) {

System.out.println("success");

} else {

System.out.println("fail");

}

}

@Override

public Site getSite() {

return site;

}

/**

* 导入单篇博客园文章数据

*

* @param url

*/

public static void importSinglePost(String url) {

Spider.create(new WebMagicCnBlogUtils())

.addUrl(url)

.addPipeline(new ConsolePipeline())

.run();

}

}

单元测试代码:

import com.blog.springboot.dto.CnBlogModelDTO;

import us.codecraft.webmagic.Page;

import us.codecraft.webmagic.Site;

import us.codecraft.webmagic.Spider;

import us.codecraft.webmagic.pipeline.ConsolePipeline;

import us.codecraft.webmagic.processor.PageProcessor;

import us.codecraft.webmagic.selector.Selectable;

public class WebMagicJunitTest implements PageProcessor {

private Site site = Site.me()

.setDomain("https://www.cnblogs.com/")

.setSleepTime(1000)

.setUserAgent("Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36");

@Override

public void process(Page page) {

Selectable obj = page.getHtml().xpath("//div[@class='post']");

Selectable title = obj.xpath("//h1[@class='postTitle']//a");

Selectable content = obj.xpath("//div[@class='blogpost-body']");

System.out.println("title:" + title.replace("]*>", ""));

System.out.println("content:" + content);

}

@Override

public Site getSite() {

return site;

}

public static void importSinglePost(String url) {

Spider.create(new WebMagicJunitTest())

.addUrl(url)

.addPipeline(new ConsolePipeline())

.run();

}

public static void main(String[] args) {

WebMagicJunitTest.importSinglePost("https://www.cnblogs.com/youcong/p/9404007.html");

}

另外我是怎么知道要爬取哪些数据呢?

需求第一,然后通过Chrome或Firefox浏览器检查元素,如图:

到此这篇关于Java爬虫框架之WebMagic实战的文章就介绍到这了,更多相关Java WebMagic内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

java webmagic_Java爬虫框架之WebMagic实战相关推荐

  1. Java爬虫框架之WebMagic的学习总结

    Java爬虫框架之WebMagic WebMagic 概述 特性 架构 四大组件 数据流转对象 控制爬虫运转的引擎Spider WebMagic的基本使用 添加WebMagic的核心与扩展依赖 爬虫实 ...

  2. Java开源爬虫框架crawler4j

    花了两个小时把Java开源爬虫框架crawler4j文档翻译了一下,因为这几天一直在学习Java爬虫方面的知识,今天上课时突然感觉全英文可能会阻碍很多人学习的动力,刚好自己又正在接触这个爬虫框架,所以 ...

  3. 在不同领域,大家用爬虫怎么盈利的-Java网络爬虫系统性学习与实战系列(4)

    在不同领域,大家用爬虫怎么盈利的-Java网络爬虫系统性学习与实战系列(4) 文章目录 概述 出行抢票软件 微博上的僵尸粉 电商比价/返利平台 社区抓取数据和内容 联系方式 系列文章地址: Java网 ...

  4. 了解爬虫的风险与以及如何规避风险-Java网络爬虫系统性学习与实战系列(3)

    了解爬虫的风险与以及如何规避风险-Java网络爬虫系统性学习与实战系列(3) 文章目录 概述 法律风险 民事风险 刑事风险 个人信息的法律风险 著作权的风险(文章.图片.影视等数据) 5不要 3准守 ...

  5. 常见的一些反爬虫策略(下篇)-Java网络爬虫系统性学习与实战系列(10)

    常见的一些反爬虫策略(下篇)-Java网络爬虫系统性学习与实战系列(10) 文章目录 联系方式 反爬虫策略 文本混淆 SVG映射 CSS文字偏移 图片混淆伪装 字体反爬 Referer字段反爬 数据分 ...

  6. InfoQ网站作者的文章列表文章详情获取-Java网络爬虫系统性学习与实战系列(13)

    InfoQ网站作者的文章列表&文章详情获取-Java网络爬虫系统性学习与实战系列(13) 文章目录 联系方式 概述 分析 配置好Xpath规则 selenium工具类 获取InfoQ文章列表 ...

  7. 掘金网站作者的文章列表文章详情获取-Java网络爬虫系统性学习与实战(14)

    掘金网站作者的文章列表&文章详情获取-Java网络爬虫系统性学习与实战(14) 文章目录 联系方式 概述 分析 配置好Xpath规则 selenium工具类 获取文章列表 获取文章详情数据 p ...

  8. java爬虫框架之webMagic

    webMagic框架 前言 介绍 案例 控制类: 解析类: 持久化类: 用到的工具类以及配置类: 注意事项 后语 前言 文章仅供安全领域的朋友学习使用!! 严禁做违法违纪的事情,责任自负 介绍 Web ...

  9. 爬虫---scrapy爬虫框架(详细+实战)

    ​ 活动地址:CSDN21天学习挑战赛 爬虫---scrapy爬虫框架 爬虫---scrapy爬虫框架 一.简介 1.基本功能 2.架构 3.scrapy项目的结构 二.scrapy环境搭建 三.如何 ...

最新文章

  1. C# 给word文档添加水印
  2. matplotlib 的几种柱状图
  3. php判断有没有分页,php分页怎么判断已经到了最后一页?
  4. brew 安装java8_mac使用brew安装Java8
  5. 数据挖掘之数据预处理
  6. ns3中调试程序------命令行、gdb和logging系统
  7. 【图像处理】MATLAB:基本原理
  8. 身为开发人员,这些数据库合知识不掌握不合适!
  9. 对接海外faceid
  10. AsyncTask使用须知
  11. C语言小程序-学生成绩统计系统
  12. 电子邮件(E-mail)和电子邮件协议
  13. android电话本导入iphone,如何将Android电话簿导入iPhone手机
  14. photoshop智能参考线
  15. CephFS MDS服务 高可用
  16. linux:使用yum安装_首次使用Linux:30个安装案例
  17. 零基础搭建Win系统Anaconda+Pytorch+OpenCV深度学习环境(Win10、Win11、RTX 3090显卡也适用)
  18. TRIZ创新思维方法_简要复习
  19. 微信公众号运营都有哪些实用小技巧,你学会了吗
  20. 2022 Java 企业面试题汇总

热门文章

  1. 《明日方舟》游戏拆解
  2. 安防天下5、6——视频编码器技术DVS、网络录像机(NVR)技术
  3. JSP学习笔记(六十):使用struts2中的codebehind插件
  4. 判定操作系统x64还是x32方法
  5. gittee添加公钥
  6. MTBF、MTTR、MTTF三个指标的区别在哪儿
  7. 各种版本的卡图.html,问下大佬们utr有几种版本的,图一的个人认为是比较好看的一种...
  8. 前端http相关常见面试题
  9. 将所有的碎片信息放进去的结构 ,大大减轻大脑的负担,更容易地解决问题
  10. Python爬虫案例3:爬取房天下房价等各种信息