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

embedded/2024/9/24 7:43:53/

        大家好,我们平时在做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/embedded/37266.html

相关文章

鸿蒙内核源码分析(工作模式篇) | CPU的七种工作模式

本篇说清楚CPU的工作模式 工作模式(Working mode) 也叫操作模式(Operating mode)又叫处理器模式(Processor mode),是 CPU 运行的重要参数,决定着处理器的工作方式,比如如何裁决特权级别和报告异…

掌握这些道理可以使人在人生的舞台上更加从容和自信。

1. 树立威信应该先严厉而后宽松,才会既让人畏惧,又受人尊重,如果先宽松而后严厉, 人们就只会怨恨你的冷酷。 2. 未老先残,未老先病,未来将一片惨淡,安全牢记在心,时刻做好预防。 3. …

游戏辅助 -- 实战找人物对象基址

本节课在线学习视频: https://pan.quark.cn/s/3e83f4568031 一、打开CE工具,加载游戏进程 二、搜索人物血量144,选择首次扫描 三、进入游戏,让人物血量发生变化,搜索减少的数值 四、发现绿色的数值,一般绿…

为什么会查询不到DNS信息?怎么排查?

DNS(域名系统)是将域名转换为相应 IP 地址的关键系统。查询 DNS 信息具有重要作用,通过查询 DNS 信息,我们可以知道域名对应的 IP 地址,这是最主要的信息,使设备能与目标服务器进行通信;其次是域…

如何使用vue脚手架创建项目

前言 使用vue搭建项目的时候,我们可以通过对应的cmd命令去打开脚手架,然后自己配置对应的功能插件 说明: 要使用Vue脚手架创建项目,你需要先确保你已经安装了Node.js和npm(Node.js的包管理器)。然后&#…

使用excel合理整理数据

使用excel合理整理数据 Excel函数LOOKUP把两个sheet数据关联起来LOOKUP函数 Excel函数LOOKUP把两个sheet数据关联起来 LOOKUP函数 需求场景 1、sheet1是视频的数据比如 aid、作者、视频信息 2、sheet2是视频的播放数据比如 aid vv uv等 做的就是根据1、2 的aid 将 sheet2中的所…

[Linux][网络][TCP][四][流量控制][拥塞控制]详细讲解

目录 1.流量控制2.拥塞控制0.为什么要有拥塞控制,不是有流量控制么?1.什么是拥塞窗口?和发送窗口有什么关系呢?2.怎么知道当前网络是否出现了拥塞呢?3.拥塞控制有哪些算法?4.慢启动5.拥塞避免6.拥塞发生7.快…

二叉搜索树相关

二叉搜索树 定义:对二叉搜索树的一些操作基本结构Insert操作Find操作Erase操作 InOrder遍历二叉树操作模拟字典模拟统计次数 定义: 二叉搜索树又称二叉排序树,它或者是一棵空树,或者是具有以下性质的二叉树:若它的左子树不为空&a…