Selenium自动下载浏览器驱动
为什么需要自动下载浏览器驱动?
血泪场景重现
-
新人入职第一天:
- 花3小时配置Chrome/Firefox驱动
- 版本不匹配导致
SessionNotCreatedException
-
浏览器自动更新后:
- 所有测试脚本突然崩溃
- 手动查找驱动耗时长
终极解决方案:自动下载驱动
✅ 动态检测浏览器版本
✅ 下载匹配的驱动程序
✅ 自动设置环境变量
3行代码极简解决方案(Python版)
安装必备库
pip install webdriver-manager # 核心神器
自动下载驱动示例
from selenium import webdriver
from webdriver_manager.chrome import ChromeDriverManager
from webdriver_manager.firefox import GeckoDriverManager# Chrome自动下载(会返回驱动路径)
driver_path = ChromeDriverManager().install() # 创建浏览器实例(无需手动指定路径)
driver = webdriver.Chrome(executable_path=driver_path)
driver.get("https://www.baidu.com")# Firefox同样简单
firefox_path = GeckoDriverManager().install()
driver = webdriver.Firefox(executable_path=firefox_path)
执行效果
[WDM] - Current google-chrome version is 124.0.6367
[WDM] - Get LATEST driver version for 124.0.6367
[WDM] - Driver [C:\Users\Sam\.wdm\drivers\chromedriver\win64\124.0.6367.78\chromedriver.exe] found in cache
核心原理拆解(文字版流程图)
1. 检测已安装的浏览器版本│├── Windows:查询注册表 `HKEY_CURRENT_USER\Software\Google\Chrome\BLBeacon`├── macOS:执行 `/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --version`├── Linux:解析 `google-chrome --version` 输出│
2. 访问官方驱动仓库(无需翻墙镜像)│├── Chrome:https://chromedriver.storage.googleapis.com├── Firefox:https://github.com/mozilla/geckodriver/releases│
3. 下载匹配版本驱动│├── 自动识别操作系统(Win/Mac/Linux)├── 解压压缩包到缓存目录│
4. 返回驱动绝对路径
进阶实战:自定义控制方案
场景1:强制更新最新驱动
# 忽略缓存强制下载
ChromeDriverManager(version="latest").install()
场景2:指定特定版本
# 下载指定版本驱动(兼容旧浏览器)
ChromeDriverManager(version="114.0.5735.90").install()
场景3:设置代理和镜像源
import os# 方法1:设置环境变量
os.environ["WDM_PROXY"] = "http://company-proxy:8080"# 方法2:代码配置
ChromeDriverManager(proxy="http://user:pass@proxy:8080", # 代理url="https://npm.taobao.org/mirrors/chromedriver" # 国内镜像
).install()
场景4:自定义缓存路径
# 修改默认存储位置
ChromeDriverManager(cache_valid_range=30, # 缓存有效期30天path="/tmp/my_drivers" # 自定义目录).install()
跨语言支持方案
语言 | 库名称 | 安装命令 |
---|---|---|
Java | webdrivermanager | mvn io.github.bonigarcia:webdrivermanager:5.6.3 |
NodeJS | webdriver-manager | npm install webdriver-manager |
C# | WebDriverManager.Net | dotnet add package WebDriverManager |
Java示例(Spring Boot)
import io.github.bonigarcia.wdm.WebDriverManager;public class AutoDriverTest {public static void main(String[] args) {// 自动下载Chrome驱动WebDriverManager.chromedriver().setup();// 创建浏览器实例WebDriver driver = new ChromeDriver();driver.get("https://baidu.com");}
}
常见故障排除指南
-
下载速度慢
- 解决方案:使用国内镜像源
ChromeDriverManager(url="https://registry.npmmirror.com/-/binary/chromedriver").install()
- 解决方案:使用国内镜像源
-
公司网络禁止访问
- 解决方案:先手动下载驱动,再指定路径
driver = webdriver.Chrome(executable_path="D:/drivers/chromedriver.exe")
- 解决方案:先手动下载驱动,再指定路径
-
证书验证错误
- 解决方案:关闭SSL验证(仅限测试环境)
ChromeDriverManager(ssl_verify=False).install()
- 解决方案:关闭SSL验证(仅限测试环境)
-
权限不足
- Linux/Mac解决方案:
sudo chmod +x /path/to/chromedriver
- Linux/Mac解决方案:
完整代码
默认是Chrome,会自动下载安装对应的版本Driver
# Selenium 4.33.0from selenium import webdriver
from selenium.webdriver.chrome.service import Service
from selenium.webdriver.chrome.options import Options
from common.tools import get_project_path, sepclass DriverConfig:def driver_config(self):"""浏览器驱动配置:return: 配置好的WebDriver实例"""# 创建ChromeOptions并配置chrome_options = Options()chrome_options.add_argument("window-size=1920,1080")# 去除"Chrome正受到自动测试软件的控制"的提示chrome_options.add_experimental_option("excludeSwitches", ["enable-automation"])# 解决selenium无法访问https的问题chrome_options.add_argument("--ignore-certificate-errors")# 允许忽略localhost上的TLS/SSL错误chrome_options.add_argument("--allow-insecure-localhost")# 设置无痕模式# chrome_options.add_argument("--incognito")# 设置为无头模式# chrome_options.add_argument("--headless")# 解决卡顿:GPU加速chrome_options.add_argument("--disable-gpu")# 解决卡顿:禁用 Chrome 的沙箱安全机制。chrome_options.add_argument("--no-sandbox")# 解决卡顿:测试用例一多的化,可能会导致内存溢出,要加上这个chrome_options.add_argument("--disable-dev-shm-usage")# Selenium 4.10+ 版本后无需手动指定driver路径,会自动管理# 但如果需要指定自定义路径,可以使用以下方式# service = Service(executable_path="/path/to/chromedriver")# 使用默认的驱动管理功能service = Service()# 使用Service和Options初始化Chrome WebDriverdriver = webdriver.Chrome(service=service, options=chrome_options)# 删除所有cookiesdriver.delete_all_cookies()return driver
如果是Firefox,需要修改参数:
#!/usr/bin/python3
# coding=utf-8
# @Time: 2025/6/5 18:18
# @Author: Samfrom selenium import webdriver
from selenium.webdriver.firefox.service import Service
from selenium.webdriver.firefox.options import Options
from common.tools import get_project_path, sepclass DriverConfig:def driver_config(self):"""浏览器驱动配置:return: 配置好的WebDriver实例"""# 创建FirefoxOptions并配置firefox_options = Options()firefox_options.add_argument("--width=1920")firefox_options.add_argument("--height=1080")# 去除"Firefox正受到自动测试软件的控制"的提示# Firefox默认不会显示此提示# 解决selenium无法访问https的问题firefox_options.accept_insecure_certs = True# 设置为无头模式# firefox_options.add_argument("--headless")# 解决卡顿:禁用GPU加速firefox_options.add_argument("--disable-gpu")# 解决卡顿:禁用沙箱安全机制firefox_options.add_argument("--no-sandbox")# 解决卡顿:禁用共享内存使用firefox_options.add_argument("--disable-dev-shm-usage")# Selenium 4.10+ 版本后无需手动指定driver路径,会自动管理# 使用默认的驱动管理功能service = Service()# 使用Service和Options初始化Firefox WebDriverdriver = webdriver.Firefox(service=service, options=firefox_options)# 删除所有cookiesdriver.delete_all_cookies()return driver
「小贴士」:点击头像→【关注】按钮,获取更多软件测试的晋升认知不迷路! 🚀
相关文章:
Selenium自动下载浏览器驱动
为什么需要自动下载浏览器驱动? 血泪场景重现 新人入职第一天: 花3小时配置Chrome/Firefox驱动版本不匹配导致SessionNotCreatedException 浏览器自动更新后: 所有测试脚本突然崩溃手动查找驱动耗时长 终极解决方案:自动下载驱…...
数据库优化实战分享:高频场景下的性能调优技巧与案例解析
在实际开发与生产运维中,数据库的性能瓶颈往往是影响系统响应速度和用户体验的关键因素。尤其是在高并发访问、海量数据处理、复杂查询逻辑等高频场景下,数据库优化不仅仅是“锦上添花”,更是“雪中送炭”。本篇博文将结合实际项目经验&#…...

Redis 过期了解
Redis 版本:5.0 : 一:过期监听: Spring Data Redis 封装了 Redis 的 Pub/Sub 功能,提供了对 key 过期事件的监听支持。 1. 核心类:KeyExpirationEventMessageListener 这个抽象类是 Spring 提供的&#x…...
微信小程序前端面经
一、技术栈与编码能力(10min) 1. Vue 3 & Composition API Q1:请解释一下 ref 和 reactive 的区别?你在项目中是如何使用的? 答:ref是包装一个原始值或对象,通过.value访问,r…...
android 之 Tombstone
Android 系统中的 Tombstone 是记录 Native 层崩溃信息的关键日志文件,当应用或系统服务因严重错误(如内存访问异常、空指针解引用等)崩溃时自动生成。以下是其核心机制与分析方法详解: 一、Tombstone 的生成机制 触发条件 当 Na…...
六级作文模板笔记
旧模板 Today there is a growing awareness that mental well-being needs to be given as much attention as physical health. In the contemporary world where change is constant and knowledge is ever-expanding, mental well-being has become increasingly importan…...

JAVA理论-JAVA基础知识
1.Java 基础 知识 1.1 面向对象的特征(了解) 面向对象的特征:封装、继承、多态、抽象 封装:就是把对象的属性和行为(数据)结合为一个独立的整体,并尽量隐藏对象的内部细节,公开我希…...

免费无限使用GPT Plus、Claude Pro、Grok Super、Deepseek满血版
渗透智能-ShirtAI,可以免费无限使用GPT Plus、Claude Pro、Grok Super、Deepseek满血版、除此之外还能免费使用AI搜索、Gemini AI、AI照片修复、AI橡皮擦、AI去背景、AI智能抠图、AI证件照、OCR识别、在线思维导图、在线绘图工具、PDF工具箱、PDF翻译。 传送入口&a…...

SoloSpeech - 高质量语音处理模型,一键提取指定说话人音频并提升提取音频清晰度和质量 本地一键整合包下载
视频教程: 一个强大的语音分离和降噪软件 SoloSpeech 是由约翰霍普金斯大学、香港中文大学、南洋理工大学、清华大学及布拉格理工大学等多所高校共同主导开源的一个创新的语音处理项目,旨在解决在多人同时说话的环境中,准确提取并清晰呈现特定…...

深入解析 Java ClassLoader:揭开 JVM 动态加载的神秘面纱
大家好,这里是架构资源栈!点击上方关注,添加“星标”,一起学习大厂前沿架构! Java 之所以能实现“一次编写,到处运行”,很大程度得益于其虚拟机(JVM)强大的跨平台能力。…...

CICD实战(一) -----Jenkins的下载与安装
服务器IPJenkins192.168.242.153gitlab192.168.242.154 1、安装工具(可选,如果有就不需要安装) sudo yum install wget net-tools 2、关闭防火墙 #关闭防火墙(如果是云服务器部署,去安全组放通对应的端口即可) systemctl stop firewalld …...
【.net core】.KMZ文件解压为.KML文件并解析为GEOJSON坐标数据集。附KML处理多线(LineString)闭环问题
通过使用ZipFile解压KMZ文件,获取其中的KML文件,并解析KML文件,输出解析后的坐标数据集。 KML文件:地理信息的标准格式 解析后的坐标数据集输出格式(GEOJSON坐标数据集):[[[经度,纬度],[经度,纬度]]] 解…...
Python打卡训练营day46——2025.06.06
知识点回顾: 不同CNN层的特征图:不同通道的特征图什么是注意力:注意力家族,类似于动物园,都是不同的模块,好不好试了才知道。通道注意力:模型的定义和插入的位置通道注意力后的特征图和热力图 …...
网络资源缓存
前端性能优化是提升用户体验和页面响应速度的关键,可以从 网络优化、资源优化、缓存优化 三个方面系统地进行。以下是详细说明: 一、网络优化(减少请求数、降低延迟、提升加载速度) 减少 HTTP 请求数量 合并请求(CSS…...
Linux中 SONAME 的作用
🧠 一、从 -lexample 到 SONAME ✅ 假设你有以下文件结构: /libexample.so → libexample.so.1 /libexample.so.1 → libexample.so.1.0.0 /libexample.so.1.0.0 # SONAME: libexample.so.1/libexample.so.2 → libexample.so.2.0.0 /libexample.so.2.0…...

Devops系列---python基础篇二
1、列表 1.1 概念 格式: 名称 [ “元素1”,“元素2”,…] #定义一个列表 computer ["主机","键盘","显示器","鼠标"]类型方法用途查index(“元素”)查看元素索引位置count(“元素”)统计元素出现的次数reverse()倒序排…...
自定义事件wpf
// 自定义控件 public class MyCustomControl : Control { public static readonly RoutedEvent MyCustomEvent EventManager.RegisterRoutedEvent( "MyCustom", RoutingStrategy.Bubbling, typeof(RoutedEventHandler), typeof(MyCustomControl) ); public event R…...

TLV4062-Q1、TLV4082-Q1迟滞电压比较器应用笔记
文章目录 主要作用应用场景关键优势典型应用示意图TLV4062-Q1 和 TLV4082-Q1 的主要作用及应用场景如下: 主要作用 精密电压监测:是一款双通道、低功耗比较器,用于监测输入电压是否超过预设阈值。 集成高精度基准电压源(阈值精度1%),内置60mV迟滞功能,可避免因噪声导致的…...
C++.OpenGL (3/64)着色器(Shader)深入
着色器(Shader)深入 着色器核心概念 #mermaid-svg-xC0jTt9mJWGVa7yE {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-xC0jTt9mJWGVa7yE .error-icon{fill:#552222;}#mermaid-svg-xC0jTt9mJWGVa7yE .error-text{fi…...

DHCP介绍
DHCP介绍 1 DHCP简述2 DHCP协议分析2.1 主要流程2.2 DHCP全部报文介绍2.3 IP租用更新报文2.4 DHCP协议抓包分析 3 DHCP应用3.1 DNSmasq参数配置3.2 DNSmasq框架代码3.2.1 创建socket监听67端口3.2.2 监听67端口3.2.3 处理DHCP请求 3.3 DNSmasq模块排障方法 4 常见问题排查4.1 问…...
李沐《动手学深度学习》d2l安装教程
文章目录 最新回答报错提醒安装对应版本安装C工具和Windows SDK 最新回答 安装旧版本即可 pip install d2l0.17.0 WARNING: Ignoring invalid distribution -pencv-python (e:\python3.10\lib\site-packages) Looking in indexes: https://pypi.tuna.tsinghua.edu.cn/simple C…...

[蓝桥杯]耐摔指数
耐摔指数 题目描述 X 星球的居民脾气不太好,但好在他们生气的时候唯一的异常举动是:摔手机。 各大厂商也就纷纷推出各种耐摔型手机。X 星球的质监局规定了手机必须经过耐摔测试,并且评定出一个耐摔指数来,之后才允许上市流通。…...
深入理解数字音频:采样率、位深与量化
在当今数字时代,音频技术已经渗透到我们生活的方方面面——从流媒体音乐到视频会议,从播客到智能家居。但你是否曾好奇过,这些美妙的声音是如何被捕捉、存储并在数字世界中重现的?本文将带你深入了解数字音频的核心概念࿰…...

2024年第十五届蓝桥杯青少Scratch初级组-国赛—画矩形
2024年第十五届蓝桥杯青少Scratch初级组-国赛—画矩形 题目点下方,支持在线编程,在线获取源码和素材~ 画矩形_scratch_少儿编程题库学习中心-嗨信奥 程序演示可点下方,支持源码获取~ 画矩形-scratch作品-少儿编程题库…...
java面试场景题: 设计⼀个微博系统
微博系统设计指南:从理论到实践 系统设计考察的核心能力 系统设计面试模拟真实工作场景,候选人需与面试官协作解决模糊问题。关键在于沟通、分析和权衡能力,而非追求完美方案。面试官关注思考过程,而非最终答案。 常见误区与改…...
市面上哪款AI开源软件做ppt最好?
市面上哪款AI开源软件做ppt最好? aippt:AiPPT - 全智能 AI 一键生成 PPT 网站形式,需要注册 ai to pptx :SmartSchoolAI/ai-to-pptx: 前端后端同时开源。 Ai-to-pptx是一个使用AI技术(DeepSeek)制作PPTX的助手,支持在…...

JMM初学
文章目录 1,线程间的同步和通信1.1, 共享内存并发模型 (Shared Memory Model)线程通信机制线程同步机制特点 1.2, 消息传递并发模型 (Message Passing Model)线程通信机制线程同步机制特点 适用场景对比 2,Java内存模型JMM2.0,Java内存模型的基础(1)内存…...
transformer和 RNN以及他的几个变体区别 改进
Transformer、RNN 及其变体(LSTM/GRU)是深度学习中处理序列数据的核心模型,但它们的架构设计和应用场景有显著差异。以下从技术原理、优缺点和适用场景三个维度进行对比分析: 核心架构对比 模型核心机制并行计算能力长序列依赖处…...

构建云原生安全治理体系:挑战、策略与实践路径
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:从传统安全走向“云原生安全” 随着企业 IT 架构从传统单体系统向容器化、微服务和云原生平台转型…...
vue-print-nb 打印相关问题
一、背景与解决方案 1、ElementUI表格打印通病,均面临边框丢失、宽度超出问题:相关解决代码有注释; 2、大多数情况下不会打印页眉页脚的日期、网址、未配置popTitle显示的undefined:相关解决代码有注释; 3、打印预览页…...