用Perl和HTTP::Tiny库的爬虫

HTTP::Tiny是Perl的一个轻量级HTTP客户端,适合简单的请求,但不像LWP那样功能全面,不过对于基本需求应该足够了。

首先,我需要熟悉HTTP::Tiny的基本用法。比如如何发起GET请求,设置user-agent,处理响应。用户可能还需要处理异常,比如连接错误或者超时。另外,可能需要设置超时时间,避免脚本卡住。用户代理的设置也很重要,有些网站会阻止默认的User-Agent。

然后,考虑用户可能需要解析HTML内容,这时候需要推荐一个模块,比如HTML::TreeBuilder或者Mojo::DOM。不过用户的问题只提到HTTP::Tiny,所以可能在回答中需要提到这些解析库作为后续步骤,但核心是抓取部分。

以下是一个使用Perl和HTTP::Tiny库编写的简单网页爬虫示例,包含详细注释和解析建议:

perl 复制代码
#!/usr/bin/perl
use strict;
use warnings;
use HTTP::Tiny;

# 创建HTTP::Tiny客户端并配置参数
my $http = HTTP::Tiny->new(
    agent      => 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36',  # 伪装浏览器User-Agent
    timeout    => 10,               # 10秒超时
    verify_SSL => 1,                # 启用SSL验证
);

# 目标URL(示例使用测试网站,实际使用时请替换并遵守robots.txt)
my $url = 'https://example.com';

# 发送HTTP GET请求
my $response = $http->get($url);

# 检查请求是否成功
if ($response->{success}) {
    # 获取响应内容(注意编码处理)
    my $content = $response->{content};
    
    # 检测内容编码(示例:假设是UTF-8)
    # 实际可能需要根据响应头或<meta>标签判断
    # utf8::decode($content);  # 如果需要转换编码
    
    # 简单输出内容(前200字符)
    print "Success! Content preview:\n";
    print substr($content, 0, 200), "\n...\n";
    
    # 这里可以添加HTML解析代码
} else {
    # 输出错误信息
    my $status = $response->{status};
    my $reason = $response->{reason} || 'Unknown error';
    warn "Request failed: $status $reason\n";
    
    # 输出详细的响应头(调试用)
    if ($response->{headers}) {
        while (my ($k, $v) = each %{$response->{headers}}) {
            warn "$k: $v\n";
        }
    }
}

### HTML解析示例(需额外安装模块)
# 使用HTML::TreeBuilder解析示例:
# use HTML::TreeBuilder;
# my $tree = HTML::TreeBuilder->new;
# $tree->parse($content);
# my $title = $tree->look_down('_tag', 'title')->as_trimmed_text;
# print "Page title: $title\n";

# 更现代的Mojo::DOM解析示例:
# use Mojo::DOM;
# my $dom = Mojo::DOM->new($content);
# say "Links:";
# $dom->find('a')->each(sub {
#     my ($el) = @_;
#     say $el->attr('href'), ' => ', $el->text;
# });

注意事项:

  1. 合法合规

    • 始终检查目标网站的robots.txt文件(通常是/robots.txt
    • 遵守网站的服务条款
    • 设置合理的请求频率(建议添加3-5秒延迟)
  2. 性能优化:

    perl 复制代码
    # 可以添加延迟(单位:秒)
    sleep 3;  # 在连续请求之间添加延迟
  3. 高级配置建议:

    perl 复制代码
    my $http = HTTP::Tiny->new(
        max_redirect => 5,      # 最大重定向次数
        default_headers => {
            referer => 'https://google.com',  # 伪造来源
            accept  => 'text/html,application/xhtml+xml',
        },
    );
  4. POST请求示例:

    perl 复制代码
    my $post_response = $http->post(
        'https://example.com/login',
        {
            content => 'user=admin&pass=123',  # 或使用Form::Tiny模块处理
            headers => { 'Content-Type' => 'application/x-www-form-urlencoded' }
        }
    );
  5. 代理支持:

    perl 复制代码
    my $http_with_proxy = HTTP::Tiny->new(
        proxy => 'http://proxy.example.com:8080',
        # 或者根据协议自动选择代理
        # proxies => {
        #    http  => 'http://proxy.example.com:8080',
        #    https => 'https://proxy.example.com:8081',
        # }
    );

建议安装的解析模块:

  • HTML::TreeBuilder:传统HTML解析器
  • Mojo::DOM(需要安装Mojolicious):更现代的CSS选择器语法
  • Web::Query:jQuery风格的HTML操作

使用前请通过CPAN安装所需模块:

bash 复制代码
cpan install HTML::TreeBuilder Mojolicious Web::Query

请根据实际需求调整代码,并始终遵守目标网站的爬取规则和相关法律法规。

相关推荐
TLuoQiu2 小时前
小电视视频内容获取GUI工具
爬虫·python
凢en2 小时前
Perl——qw()函数
开发语言·perl
AliciaIr9 小时前
深入理解HTTP:从协议基础到版本演进(上)
前端·http
今禾9 小时前
深入解析HTTP协议:从OSI模型到HTTP/3.0的演进与实战优化
前端·http·面试
麦麦大数据10 小时前
F004 新闻可视化系统爬虫更新数据+ flask + mysql架构
爬虫·mysql·flask·可视化·新闻
python-行者11 小时前
akamai鼠标轨迹
爬虫·python·计算机外设·akamai
FreeBuf_1 天前
CERT/CC警告:新型HTTP/2漏洞“MadeYouReset“恐致全球服务器遭DDoS攻击瘫痪
服务器·http·ddos
NEUMaple1 天前
python爬虫(四)----requests
开发语言·爬虫·python
Mr_Xuhhh1 天前
传输层协议TCP(3)
运维·服务器·网络·网络协议·tcp/ip·http·https
lsnm1 天前
【LINUX网络】HTTP协议基本结构、搭建自己的HTTP简单服务器
linux·运维·服务器·c语言·网络·c++·http