Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >深度解析:使用ChromeDriver和webdriver_manager实现无头浏览器爬虫

深度解析:使用ChromeDriver和webdriver_manager实现无头浏览器爬虫

原创
作者头像
jackcode
发布于 2025-02-10 03:09:57
发布于 2025-02-10 03:09:57
41200
代码可运行
举报
文章被收录于专栏:爬虫资料爬虫资料
运行总次数:0
代码可运行
爬虫代理
爬虫代理

问题背景

在现代网络爬虫的实践中,动态网页的内容加载和复杂的反爬虫机制使得数据采集变得愈发困难。传统的静态网页爬取方法已无法满足需求,尤其是在需要模拟用户行为、处理JavaScript渲染的场景下。为此,采用无头浏览器(Headless Browser)技术成为一种有效的解决方案。

无头浏览器能够在后台运行,模拟真实用户的浏览器行为,执行JavaScript脚本,获取动态加载的内容。然而,直接使用Selenium的ChromeDriver可能会暴露出自动化的痕迹,导致被目标网站识别为爬虫。为此,需要采取措施,如设置代理IP、伪装User-Agent和处理Cookies,以提高爬虫的隐蔽性和稳定性。

技术架构图与核心模块拆解

以下是使用ChromeDriver和webdriver_manager实现无头浏览器爬虫的技术架构图:

代码语言:plain
AI代码解释
复制
+-------------------+
|   用户请求        |
+-------------------+
         |
         v
+-------------------+
|   Selenium        |
|   WebDriver       |
+-------------------+
         |
         v
+-------------------+
|   ChromeDriver    |
+-------------------+
         |
         v
+-------------------+
|   Chrome浏览器    |
|   (无头模式)      |
+-------------------+
         |
         v
+-------------------+
|   目标网站        |
+-------------------+

核心模块拆解:

  1. Selenium WebDriver:用于驱动浏览器,模拟用户行为,如点击、滚动等。
  2. ChromeDriver:Selenium与Chrome浏览器之间的桥梁,负责执行Selenium指令。
  3. Chrome浏览器(无头模式):在后台运行的浏览器实例,执行JavaScript,加载动态内容。
  4. 代理IP设置:通过配置代理服务器,隐藏真实IP,避免被目标网站封禁。
  5. User-Agent伪装:修改浏览器的User-Agent,模拟不同的设备和浏览器,降低被识别为爬虫的风险。
  6. Cookies处理:管理和维护Cookies,模拟真实用户的会话状态。

性能对比数据与行业应用案例

在实际应用中,使用无头浏览器爬虫相较于传统的静态网页爬取方法,具有以下优势:

  • 动态内容加载:能够获取JavaScript渲染的动态内容,适用于现代复杂网页。
  • 模拟用户行为:通过模拟点击、滚动等操作,获取完整的网页数据。
  • 反爬虫规避:通过设置代理IP、伪装User-Agent和处理Cookies,降低被识别为爬虫的风险。

行业应用案例:

  • 电商价格监控:通过模拟用户行为,获取电商平台的商品价格和库存信息,进行价格监控和竞争分析。
  • 社交媒体数据采集:获取社交媒体平台的用户评论、点赞数等数据,用于舆情分析和市场研究。
  • 招聘信息抓取:从招聘网站获取职位信息,进行人才市场分析和招聘策略制定。

实现代码示例

以下是使用ChromeDriver和webdriver_manager实现无头浏览器爬虫的代码示例,包含代理IP、User-Agent和Cookies的设置,以及采集TikTok视频简介和评论的功能:

代码语言:python
代码运行次数:0
运行
AI代码解释
复制
import time
import base64
import zipfile
import string
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.action_chains import ActionChains

# 代理服务器配置(以亿牛云爬虫代理 为例)
proxy_host = "proxy.16yun.cn"  # 代理服务器域名
proxy_port = "3111"  # 代理服务器端口
proxy_user = "16yun"  # 代理用户名
proxy_pass = "16IP"  # 代理密码

# 创建代理认证扩展
def create_proxy_auth_extension(proxy_host, proxy_port, proxy_username, proxy_password, scheme='http', plugin_path=None):
    if plugin_path is None:
        plugin_path = f'/tmp/{proxy_username}_{proxy_password}@{proxy_host}.zip'

    manifest_json = """
    {
        "version": "1.0.0",
        "manifest_version": 2,
        "name": "Proxy Auth",
        "permissions": [
            "proxy",
            "tabs",
            "unlimitedStorage",
            "storage",
            "<all_urls>",
            "webRequest",
            "webRequestBlocking"
        ],
        "background": {
            "scripts": ["background.js"]
        },
        "minimum_chrome_version": "22.0.0"
    }
    """

    background_js = string.Template("""
    var config = {
        mode: "fixed_servers",
        rules: {
            singleProxy: {
                scheme: "${scheme}",
                host: "${host}",
                port: parseInt(${port})
            },
            bypassList: ["foobar.com"]
        }
    };

    chrome.proxy.settings.set({value: config, scope: "regular"}, function() {});

    function callbackFn(details) {
        return {
            authCredentials: {
                username: "${username}",
                password: "${password}"
            }
        };
    }

    chrome.webRequest.onAuthRequired.addListener(
        callbackFn,
        {urls: ["<all_urls>"]},
        ['blocking']
    );
    """).substitute(
        host=proxy_host,
        port=proxy_port,
        username=proxy_username,
        password=proxy_password,
        scheme=scheme,
    )

    with zipfile.ZipFile(plugin_path, 'w') as zp:
        zp.writestr("manifest.json", manifest_json)
        zp.writestr("background.js", background_js)

    return plugin_path

# 创建代理认证扩展
proxy_auth_plugin_path = create_proxy_auth_extension(
    proxy_host=proxy_host,
    proxy_port=proxy_port,
    proxy_username=proxy_user,
    proxy_password=proxy_pass
)

# 设置Chrome选项
chrome_options = Options()
chrome_options.add_argument('--headless')  # 无头模式
chrome_options.add_argument('--disable-gpu')
chrome_options.add_argument('--no-sandbox')
chrome_options.add_argument('--disable-dev-shm-usage')
chrome_options.add_argument('lang

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Selenium 如何使用代理 IP 进行 Web 爬虫(无认证实现、有账号密码认证实现)
👋 你好,我是 Lorin 洛林,一位 Java 后端技术开发者!座右铭:Technology has the power to make the world a better place.
Lorin 洛林
2024/01/02
4.7K0
Selenium 如何使用代理 IP 进行 Web 爬虫(无认证实现、有账号密码认证实现)
Selenium + Chrome Diver密码认证的HTTP代理
默认情况下,Chrome的–proxy-server=”http://ip:port”参数不支持设置用户名和密码认证。这样就使得”Selenium + Chrome Driver”无法使用HTTP Basic Authentication的HTTP代理。一种变通的方式就是采用IP地址认证,但在国内网络环境下,大多数用户都采用ADSL形式网络接入,IP是变化的,也无法采用IP地址绑定认证。因此迫切需要找到一种让Chrome自动实现HTTP代理用户名密码认证的方案。
周小董
2019/03/25
2.7K0
[1296]selenium配置带用户名和密码的隧道代理
参考:https://blog.csdn.net/crayonjingjing/article/details/137596882 https://segmentfault.com/q/1010000043258582
周小董
2024/11/24
3920
爬虫中无头浏览器如何选择
我们日常使用浏览器的步骤为:启动浏览器、打开一个网页、进行交互。而无头浏览器指的是我们使用脚本来执行以上过程的浏览器,能模拟真实的浏览器使用场景。主要是用作爬虫,用以捕捉Web上的各类数据;这里的无头主要是指没有界面,完全是后台操作。它就是一个真实的浏览器。只是这个浏览器是无界面的。 在爬虫中使用无头浏览器有很多的注意事项,比如我们的业务场景是否适合使用无头浏览器、我们可以通过这些方面进行判别,如果目标网站反爬不是很难,可以直接通过简单的http请求进行采集,不适合使用无头浏览器方案。反之如果网站有多种验证机制,例如需要验证登录、js反爬策略,如果研发不能进行网站行为分析的情况下,建议使用无头浏览器伪装正常用户,并且需要搭配代理一起使用,代理建议使用像亿牛云提供的爬虫代理去访问网站效果会更好,这里简单的示例下使用代理的方式:
小白学大数据
2024/06/08
2260
selenium+chrome不关闭浏览器的情况下如何换IP?
Selenium是一种用于自动化浏览器的工具,可以用于模拟用户行为,特别是在访问需要进行登录的网站的时候,直接可以使用Selenium和HTTP代理来模拟真实用户行为,绕过网站反爬虫机制,以及保护我们的隐私。那如何在Selenium中使用代理并访问目标网站,一般Selenium都是使用ChromeDriver来控制浏览器。
小白学大数据
2023/03/16
1.9K1
Linux中Chrome无界模式动态代理IP的配置(Selenium)
Python 爬虫设置代理的方式有很多, 比如给urlib、request、selenium等方式设置代理,这部分的细节代码在网上一搜一大堆。那么问题来了,比如你要抓取淘宝或模拟验证码操作登录,是不是要采用这种方式(Selenium + Chromedriver + Chrome)实现呢?
蒋老湿
2020/06/28
4.3K0
Linux中Chrome无界模式动态代理IP的配置(Selenium)
Selenium爬虫过程中遇到弹窗验证
我们在做爬虫的时候,会遇到一些商业网站对爬虫程序限制较多,在数据采集的过程中对爬虫请求进行了多种验证,导致爬虫程序需要深入分析目标网站的反爬策略,定期更新和维护爬虫程序,增加了研发的时间和投入成本。这种情况下,使用无头浏览器例如 Selenium,模拟用户的请求进行数据采集是更加方便快捷的方式。同时为了避免目标网站出现IP限制,配合爬虫代理,实现每次请求自动切换IP,能够保证长期稳定的数据采集。以python的demo为例:
小白学大数据
2023/04/28
4470
浏览器自动化检测对抗:修改navigator.webdriver属性的底层实现
在使用 Selenium 或 Playwright 等浏览器自动化工具爬取数据时,经常会遇到「被检测」问题,尤其像 Amazon 这样反爬策略严密的网站。常见的检测机制之一就是检查 JavaScript 中的 navigator.webdriver 属性:
jackcode
2025/04/15
2200
浏览器自动化检测对抗:修改navigator.webdriver属性的底层实现
如何避免Selenium爬虫被网站识破
在对一些需要进行登陆操作的网站爬取时,通常都会使用到Selenium。但是Selenium爬虫在爬取数据时也是会被网站检测到,这是因为Selenium模拟了浏览器行为,而相对于真实用户的浏览器,Selenium模拟无法识别JavaScript代码和CSS文件。此外,网站也可能通过检测请求头、IP地址、Cookie等信息来判断是否是爬虫。
小白学大数据
2023/05/31
1.6K0
深度解析:使用 Headless 模式 ChromeDriver 进行无界面浏览器操作
为了解决这些问题,无界面浏览器(Headless Browser)技术应运而生。无界面浏览器是一种没有图形界面的浏览器,它能够在后台运行并模拟用户的浏览器行为。相比传统爬虫,它能够绕过网站的反爬机制,并高效处理动态加载的内容。
jackcode
2025/02/19
2750
深度解析:使用 Headless 模式 ChromeDriver 进行无界面浏览器操作
Python自动化测试Selenium+chrome连接HTTP代理(账密+白名单)
Selenium 有很多功能, 但其核心是 web 浏览器自动化的一个工具集,它允许用户模拟终端用户执行的常见活动;将文本输入到字段中,选择下拉值和复选框,并单击文档中的链接。 它还提供许多其他控件,比如鼠标移动、任意 JavaScript 执行等等。
阿秋数据采集
2022/12/16
1.2K0
python爬虫中“动态网页”如何爬取
经常会在一些爬虫群里面看到这样的提问,为什么用Python爬虫请求某个网页时,有时打印的数据不全或者什么数据都没有或者只有html骨架代码。这是因为涉及到了”动态网页数据“这个词了,简单而言,就是后台的数据不是请求网页链接时就已经将数据写入到相应的标签上了,而是利用ajax请求将后台的数据写入到相应的标签上。通常要得到这些数据,可以有两种方式,其一为找到这个ajax请求链接,然后访问这个链接,解析相应的json数据即可;另外一种是使用selenium访问这个网址,等待网页加载完之后,然后解析相应的html标签得到这些数据。
小白学大数据
2023/06/27
7470
Selenium使用代理出现弹窗验证如何处理
部分商业网站对爬虫程序限制较多,在数据采集的过程中对爬虫请求进行了多种验证,导致爬虫程序需要深入分析目标网站的反爬策略,定期更新和维护爬虫程序,增加了研发的时间和投入成本。这种情况下,使用无头浏览器例如Selenium,模拟用户的请求进行数据采集是更加方便快捷的方式。同时为了避免目标网站出现IP限制,配合爬虫代理,实现每次请求自动切换IP,能够保证长期稳定的数据采集。以python的demo为例:
小白学大数据
2024/06/08
2520
Python爬虫-selenium
对于python爬虫的相关知识之前分享了很多,这回来说说如何利用selenium自动化获取网页信息。通常对于异步加载的网页,我们需要查找网页的真正请求,并且去构造请求参数,最后才能得到真正的请求网址。而利用selenium通过模拟浏览器操作,则无需去考虑那么多,做到可见即可爬。当然带来便捷的同时,也有着不利,比如说时间上会有所增加,效率降低。可是对于业余爬虫而言,更快的爬取,并不是那么的重要。
小白学大数据
2023/05/12
7050
无头浏览器与请求签名技术-Cloudflare防护
在实际数据采集实践中,许多目标网站(例如 Amazon)都会采用 Cloudflare 等防护措施,防止机器人和非正常流量。本文将分享一个故障场景下的排查与改进方案,讲述如何利用无头浏览器、请求签名技术以及爬虫代理 IP来实现数据采集。
jackcode
2025/03/11
2301
无头浏览器与请求签名技术-Cloudflare防护
用python调用selenium获取浏览器新窗口的 cookie 信息
Cookie 是网站用于存储用户信息的一些数据文件,它们可以使网站记住用户的登录状态、偏好设置和本地内容等。Cookie 有两种类型:第一方 Cookie 是由您访问过的网站创建的,第三方 Cookie 是由其他网站创建的。
jackcode
2023/05/17
3K0
用python调用selenium获取浏览器新窗口的 cookie 信息
无头浏览器Selenium的使用要点
无头浏览器是指可以在图形界面情况下运行的,可以模拟多种浏览器的运行框架。研发可以通过编程来控制该框架执行各种任务,模拟真实的浏览器操作和各种任务,例如登录、js解析、ajax动态生成、获取cookie等。
用户6172015
2021/07/06
2.9K0
高温导致大闸蟹价格暴涨
金秋临近,一年之中品尝螃蟹的好季节即将到来。但由于天气炎热,近期大闸蟹“食欲不振”,生长也受到了影响。然而,影响更深的是,由于高温,缺氧的大闸蟹“死伤严重”大闸蟹减产也导致其价格激增,今年大闸蟹价格比去年同期涨40%。大闸蟹一直都以来都比较贵,现在更是涨价,那估计很多人会被价格劝退吧?
小白学大数据
2022/08/31
5880
Python调用ip代理案例,快代理api调用demo
Python调用ip代理案例,demo,参考官方给出的案例,整理,这里使用的是快代理api,可以实现ip代理的更换,主要整理了requests的调用以及无头浏览器 Chrome的使用,同时使用了站长之家ip检测的api工具!
二爷
2020/10/19
2.3K0
Python调用ip代理案例,快代理api调用demo
Scrapy+Chromium+代理+
js是爬虫中毕竟麻烦处理的一块。通常的解决办法是通过抓包,然后查看request信息,接着捕获ajax返回的消息。 但是,如果遇到一些js渲染特别复杂的情况,这种办法就非常非常的麻烦。所以我们采用了selenium这个包,用它来调用chromium完成js渲染的问题。
py3study
2020/01/02
1.2K0
推荐阅读
相关推荐
Selenium 如何使用代理 IP 进行 Web 爬虫(无认证实现、有账号密码认证实现)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验