在Linux上使用Selenium驱动Chrome浏览器无头模式

devtools/2024/10/19 7:25:55/

        大家好,我们平时在做UI自动化测试的时候,经常会用到Chrome浏览器的无头模式(无界面模式),并且将测试代码部署到Linux系统中执行,或者平时我们写个爬虫爬取网站的数据也会使用到,接下来和大家分享一下在Linux系统中使用Chrome无头模式。

关于Linux常用命令,大家可以参考:作为测试人员的Linux常用命令

一、在Linux上安装Chrome浏览器

1、首先要先安装Chrome浏览器所需要的依赖包

yum install -y wget unzip libX11 GConf2 fontconfig

安装完成后如下图:

2、下载Chrome浏览器

cd /opt
wget https://dl.google.com/linux/direct/google-chrome-stable_current_x86_64.rpm

3、下载完成后通过yum安装

yum install -y google-chrome-stable_current_x86_64.rpm

安装完成后如下图:

查看Chrome浏览器的版本,下载对应的webdriver,此处的浏览器版本为:124.0.6367.118

google-chrome --version

二、安装Chrome WebDriver

Chrome WebDriver下载地址(浏览器版本114之前):

https://chromedriver.storage.googleapis.com/index.html

Chrome WebDriver下载地址(浏览器版本123以后): 

Chrome for Testing availability

找到对应版本的WebDriver进行linux版本的下载,有时候没有对应版本的chromedriver则安装低一个版本的也可以。

此处,我得Chrome浏览器版本为 124.0.6367.118,找到对应版本的linux安装包,但是被标红显示HTTP status 是404了,无法下载。

只能选择低一个版本的下载了

复制下载链接,在linux系统中直接下载,或者本机下载完成后上传到服务器也可以。 

wget https://storage.googleapis.com/chrome-for-testing-public/124.0.6367.91/linux64/chromedriver-linux64.zip

下载完成后,对压缩包进行解压

unzip chromedriver_linux64.zip

 解压完成后,出现一个相同名字的目录

进入到目录中可以看到浏览器驱动文件

将解压后的 chromedriver 移动或者复制到 /usr/local/bin/ 目录下

mv chromedriver /usr/local/bin/

验证ChromeWebDriver是否安装成功

chromedriver --version

三、配置Python3环境

此处省略,参考:Linux安装Python3.9环境

四、安装selenium

pip3 install selenium

安装完成后如下图:

五、编写脚本

创建一个python文件,命名为chrome_test.py

touch chrome_test.py

通过vi编辑器编辑文件

vi chrome_test.py

文件内容如下:

python"># -*- coding:utf-8 -*-
from selenium import webdriver
from selenium.webdriver.chrome.options import Optionsoptions = Options()
# 启用无头模式
options.add_argument('--headless')options.add_argument('--no-sandbox')
options.add_argument('--disable-gpu')
options.add_argument('--disable-dev-shm-usage')
options.add_argument('--remote-debugging-port=9222')
# 创建 WebDriver 对象
driver = webdriver.Chrome(options=options)
print('以无头模式驱动浏览器')
# 打开百度首页
driver.get(url='https://www.baidu.com')
print('访问百度')
# 关闭浏览器
driver.quit()
print('关闭浏览器')

编辑完成后,保存文件。

六、运行脚本

python">python3 chrome_test.py

运行后,出现下面报错,原因是因为我本机的 urllib3 和 ssl 模块之间的版本不匹配,需要对 urllib3 模块进行降级

降级urllib3模块的版本

python">pip3 install urllib3==1.26.7

降级完成后,重新运行脚本。

运行成功!大功告成!!


http://www.ppmy.cn/devtools/35832.html

相关文章

X 推出 Stories 功能,由 Grok AI 生成新闻摘要

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

前端开发中可能出现内存泄漏的情况总结

前端开发中可能出现内存泄漏的情况主要包括以下几种: 1. 闭包引起的循环引用 当一个函数内部引用了外部作用域的变量,并且该函数的作用域链没有被适时断开,就可能形成循环引用。特别是当DOM元素的事件处理函数使用闭包访问外部变量时&#…

excel中数据筛选技巧

1、筛选excel中破折号前后都为空的数据 在Excel中查找破折号前后为空的数据,你可以结合使用Excel的查找和筛选功能,或者利用一些公式来判断。以下是两种常用的方法: 方法一:使用筛选功能选中数据范围:首先&#xff0c…

MWeb Pro for Mac:功能强大的Markdown博客编辑器

MWeb Pro for Mac是一款功能强大的Markdown博客编辑器,专为Mac用户设计,提供了一站式的博客写作和发布体验。这款软件不仅支持Markdown语法,还提供了丰富的编辑和排版功能,让用户能够轻松创建出精美的博客内容。 MWeb Pro的即时预…

【OpenVINO™】在 C# 中使用OpenVINO™ 部署 YOLO-World 模型实现实时开放词汇对象检测

YOLO-World是一个融合了实时目标检测与增强现实(AR)技术的创新平台,旨在将现实世界与数字世界无缝对接。该平台以YOLO(You Only Look Once)算法为核心,实现了对视频中物体的快速准确识别,并通过…

validation的简单使用

首先是依赖 我这里使用的是 web 工程&#xff0c;所以多一个web依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId></dependency><dependency><groupId>…

Canal:MySQL Binlog解析与增量数据订阅实战指南

引言 在现代数据驱动的业务场景下&#xff0c;数据的实时性和一致性变得至关重要。阿里巴巴开源的Canal项目&#xff0c;作为一款强大的MySQL数据库增量日志解析工具&#xff0c;为数据订阅与消费提供了一站式的解决方案。本文将深入介绍Canal的基本概念、工作原理、特性优势以…

学生管理系统初级

根据题目要求生成大纲 总结: 1.在书写时&#xff0c;考虑到了书写时id可是是abc... 类型是String&#xff0c;但在根据id获取集合中元素时 list.get() &#xff0c;get&#xff08;&#xff09;里面是int类型。 2.在书写还有一点功能并不完全&#xff0c; 2.1查找时是打印所有…