当前位置: 代码网 > it编程>编程语言>安全编程 > Portia开源可视化爬虫工具的使用学习

Portia开源可视化爬虫工具的使用学习

2024年05月15日 安全编程 我要评论
背景由于最近在写一个可供配置的爬虫模板,方便快速扩展新的抓取业务,并且最后目标是将其做成一个可视化的配置服务。还正在进行中,并且有点没有头绪,所以想参考网上现有的轮子,看看能不能找到点新的思路。安装d

背景

由于最近在写一个可供配置的爬虫模板,方便快速扩展新的抓取业务,并且最后目标是将其做成一个可视化的配置服务。还正在进行中,并且有点没有头绪,所以想参考网上现有的轮子,看看能不能找到点新的思路。

安装

docker安装完成后拉去portia服务项目

# < ..folder> 路径自定义即可 , 可在后面加上portia的版本
docker run -i -t --rm -v <projects_folder>:/app/data/projects:rw -p 9001:9001 scrapinghub/portia
# git上是如下语句
docker run -v ~/portia_projects:/app/data/projects:rw -p 9001:9001 scrapinghub/portia

具体可参考官方文档

使用portia包

新建project

portia安装完成以后使用浏览器打开http://localhost:9001, 在create a new project 中输入项目名

在这里插入图片描述

点击 new spider 创建一个新的spider
右边侧栏会提示你输入一个url,portia会将网页的url作为一个start page。

这个start page一般被用来当做seek(种子),用来获得更多的链接。

在这里插入图片描述
portia支持创建 page sample(页面样本),当你创建了一个页面样本,就可以调度后面的任务按照你设定的模板抓取元素。(所以我们需要先创建这样的模板)

page sample

创建了sample之后,我们可以开始注释页面。注释会将页面中的一条数据链接到项目字段。这些即是我们想要提取的数据

在这里插入图片描述

字段命名,选择数据类型

在这里插入图片描述

portia默认遵循所有域内url。在许多情况下,您需要限制portia将访问的页面,以便不会在不相关的页面上浪费请求。

为此,您可以分别设置跟随和排除白名单和黑名单url的模式。可以通过将爬网策略更改为来配置这些。configure url patterns

在这里插入图片描述

到此操作结束

可以在最右侧看到我们选中的项目,将所有需要提取的items注释完之后,关闭样本。close sample,如果以后需要再添加其他元素,继续配置此样本,方便后续的抓取。

最后,我们可以在右边看到我们需要的数据,json如下格式

启动程序

我们配置好了sample page和start pages,那么就要开始抓取数据了,也就是将数据保存到json文件或者数据库中。这里我们保存成json文件

官方给出的代码如下

docker run -i -t --rm -v projects_folder:/app/data/projects:rw -v ouput_folder:/mnt:rw -p 9001:9001 scrapinghub/portia \ 
portiacrawl /app/data/projects/project_name spider_name -o /mnt/result.json

其中可以更改的是大写的那些部分:projects_folder / ouput_folder / project_name / spider_name / result.json
依次是: 项目名 / 输出目录 / project的名字 / spider名字 / 保存结果的文件

启动程序前必须先关闭portia的调试页面,这里我直接使用kill命令,因为我在docker启动的终端按下ctrl+c 或 crtl+z都无效,只能用进程关闭

例如,我的启动代码如下:

docker run -i -t --rm -v ~/portia_projects:/app/data/projects:rw -v ~/result:/mnt:rw -p 9001:9001 scrapinghub/portia \ 
portiacrawl /app/data/projects/tingyun tingyun.site -o /mnt/tingyun.json

运行成功就能看见代码在飞快地跑了,而且都是我们想要的items

总结

到此,我们就结束了这一次使用portia的抓取之旅,通过使用portia确实能实现很快速简易的抓取功能,能将抓取过程可视化得呈现给操作者,还有其他有趣的功能在后续的学习中遇到再次分享给大家,接下来会去考虑试着将其用到一些大规模的抓取上,看看到底效果如何,更多关于portia开源可视化爬虫工具的资料请关注代码网其它相关文章!

(0)

相关文章:

  • Iptables防火墙四表五链概念及使用技巧详解

    Iptables防火墙四表五链概念及使用技巧详解

    1.链的概念在防火墙中,用户想要成功进入内网环境,就需要发送请求报文,请求报文要和防火墙设置的各种规则进行匹配和判断,最后执行相应的动作(放行或者拒绝),一个防... [阅读全文]
  • 详解常见web攻击手段

    web攻击在互联网中,攻击手段数不胜数,我们平时不能以自己只是普通的开发程序员而不是安全方向的开发者为理由,而不去掌握基本的 web 攻击手段!我们来熟悉一下有哪几种常见的 web…

    2024年05月15日 编程语言
  • Iptables防火墙基本匹配条件应用详解

    Iptables防火墙基本匹配条件应用详解

    引言@[toc] 应用匹配条件时,经常会用到以下几个参数。-p:指定要操作的协议类型,不指定-p参数声明是那种协议,默认是all,也就是所有协议。-s:指定源地... [阅读全文]
  • WEB前端常见受攻击方式及解决办法总结

    WEB前端常见受攻击方式及解决办法总结

    一个网站建立以后,如果不注意安全方面的问题,很容易被人攻击,下面就讨论一下几种漏洞情况和防止攻击的办法。一、sql注入  所谓sql注入,就是通过把sql命令插... [阅读全文]
  • Iptables防火墙自定义链表实现方式

    Iptables防火墙自定义链表实现方式

    1.为什么要自定义链为什么需要自定义链呢?默认的四表五链不满足基本使用吗?其实并不是,四表五链完全满足使用,但是当我们同一类程序有很多个防火墙规则时,例如都写在... [阅读全文]
  • 10个好用的Web日志安全分析工具推荐小结

    经常听到有朋友问,有没有比较好用的web日志安全分析工具?首先,我们应该清楚,日志文件不但可以帮助我们溯源,找到入侵者攻击路径,而且在平常的运维中,日志也可以反应出很多的安全攻击行…

    2024年05月15日 编程语言

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com