用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

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

相关推荐
水w4 小时前
【Python爬虫】简单介绍
开发语言·爬虫·python·beautifulsoup
游戏开发爱好者85 小时前
Flutter 学习之旅 之 flutter 使用 shared_preferences 实现简单的数据本地化保存封装
websocket·网络协议·tcp/ip·http·网络安全·https·udp
unix2linux7 小时前
YOLO v5 Series - HTTP-FLV - FFmpeg & (HTML5 + FLV.js ) Integrating
yolo·http·ffmpeg
大神薯条老师9 小时前
Python高级爬虫之JS逆向+安卓逆向1.4节:数据运算
爬虫·python·机器学习·数据分析·网络爬虫
q567315239 小时前
使用Scrapy库结合Kotlin编写爬虫程序
爬虫·scrapy·kotlin
水w9 小时前
【Python爬虫】简单介绍2
开发语言·爬虫·python·beautifulsoup
小白学大数据10 小时前
Scrapy结合Selenium实现搜索点击爬虫的最佳实践
开发语言·chrome·爬虫·selenium·scrapy
谢尔登14 小时前
【uni-app】axios 报错:Error: Adapter ‘http‘ is not available in the build
网络协议·http·uni-app
小白学大数据14 小时前
Python自动化爬虫:Scrapy+APScheduler定时任务
开发语言·爬虫·python·自动化