随笔 - 82  文章 - 2 评论 - 1 阅读 - 29061
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

圣诞节又到了,又是一个天上飞着驯鹿、家里摆着圣诞树、树下还有礼物的日子。上班路上看到很多店家都在店里摆了一颗挂满礼物盒的圣诞树,很多朋友也会在网上购买一颗小小的圣诞树来过一个氛围感满满的圣诞节。

今天我们就使用python爬虫技术看下淘宝上圣诞树的价格信息,给大家做个参考。在爬取数据前我们需要了解,像淘宝这样大的电商网站,怎么可能是简答的爬虫随随便便就能获取到数据的。淘宝的反爬机制是非常严的,如果爬虫程序做的不够好,也就只能获取少量的数据。对于反爬机制的应对,今天我们主要讲下网站限制ip访问改怎么解决。一般情况下都是加代理,但是代理的选择也是很重要的,网上的代理千千万,真正靠谱的只有那么几家。像某牛云就是其中一家。我们就以他们提供的爬虫代理访问淘宝获取数据,简单的代理使用部分如下:

<?php
    // 要访问的目标页面
    $url = "https://www.taobao.com/";
    $urls = "https://www.taobao.com/";

    // 代理服务器(产品官网 www.16yun.cn)
    define("PROXY_SERVER", "tcp://t.16yun.cn:31111");

    // 代理身份信息
    define("PROXY_USER", "16AHZUZZ");
    define("PROXY_PASS", "758977");

    $proxyAuth = base64_encode(PROXY_USER . ":" . PROXY_PASS);

    // 设置 Proxy tunnel
    $tunnel = rand(1,10000);

    $headers = implode("\r\n", [
        "Proxy-Authorization: Basic {$proxyAuth}",
        "Proxy-Tunnel: ${tunnel}",
    ]);
    $sniServer = parse_url($urls, PHP_URL_HOST);
    $options = [
        "http" => [
            "proxy"  => PROXY_SERVER,
            "header" => $headers,
            "method" => "GET",
            'request_fulluri' => true,
        ],
        'ssl' => array(
                'SNI_enabled' => true, // Disable SNI for https over http proxies
                'SNI_server_name' => $sniServer
        )
    ];
    print($url);
    $context = stream_context_create($options);
    $result = file_get_contents($url, false, $context);
    var_dump($result);

    // 访问 HTTPS 页面
    print($urls);
    $context = stream_context_create($options);
    $result = file_get_contents($urls, false, $context);
    var_dump($result);
?>

代理的使用部分对很多新手小伙伴来说是很有学习价值的,关于更多的示例可以关注下官网https://www.16yun.cn/help/

 
 
posted on   小橙子11  阅读(71)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
点击右上角即可分享
微信分享提示