【go语言】Chromeless简介及Chromedp库实现模拟登录截屏

2023-12-29 18:20

本文主要是介绍【go语言】Chromeless简介及Chromedp库实现模拟登录截屏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、什么是Chromeless

chromeless 是一个基于 Node.js 的库,用于通过无头浏览器(Headless Chrome)进行自动化测试和网页截图。它允许开发者使用 JavaScript 脚本来控制和操作浏览器,而无需实际打开浏览器窗口。

以下是一些 chromeless 的主要特性和用法:

  1. 基于 Chrome DevTools Protocol:chromeless 使用 Chrome DevTools Protocol(CDP)与浏览器进行通信。这允许对浏览器进行底层的控制和操作。
  2. 支持无头模式: 由于使用 Headless Chrome,chromeless 在执行测试和脚本时不会显示实际的浏览器界面,从而提高了效率。
  3. 链式调用:chromeless 的 API 设计允许使用链式调用,使代码看起来更清晰和易读。
  4. 截图和PDF生成: 可以使用 chromeless 进行页面截图和生成 PDF 文件,这对于测试和生成报告非常有用。
  5. 表单提交和用户交互: 支持模拟用户在页面上的交互,比如点击、输入文本等操作。
  6. 异步执行:chromeless 支持异步操作,可以等待页面加载完成或等待特定的事件发生。

以下是一个简单的 chromeless 示例:

const { Chromeless } = require('chromeless');async function run() {const chromeless = new Chromeless();const screenshot = await chromeless.goto('https://www.example.com').screenshot();console.log(screenshot); // 返回截图的 Bufferawait chromeless.end();
}run().catch(console.error);

在这个示例中,chromeless 打开了一个 Headless Chrome 浏览器,导航到了 https://www.example.com,然后截取了页面的屏幕截图。这只是 chromeless 的基本用法,它提供了更多的功能,可以满足自动化测试和其他网页操作的需求。

二、go语言中的实现

在 Go 语言中,要使用无头浏览器进行自动化测试和网页操作,可以考虑使用一些第三方库。以下是一些常见的用于在 Go 中进行无头浏览器测试的库:

1. Chromedp:Chromedp 是一个基于 Chrome DevTools Protocol 的库,允许你在无头浏览器中执行操作。它提供了对 Chrome DevTools 的直接访问,以及一些高级功能,如截图、模拟用户输入等。GitHub 地址:GitHub - chromedp/chromedp: A faster, simpler way to drive browsers supporting the Chrome DevTools Protocol.

  package mainimport ("context""log""github.com/chromedp/chromedp")func main() {ctx, cancel := chromedp.NewContext(context.Background())defer cancel()var buf []byteif err := chromedp.Run(ctx,chromedp.Navigate("https://www.example.com"),chromedp.CaptureScreenshot(&buf),); err != nil {log.Fatal(err)}// 处理截图数据(buf)}

2. Headless Chrome with Puppeteer Go:Headless Chrome with Puppeteer Go 是一个使用 Puppeteer 和 Go 的库,使得在 Go 中能够方便地控制 Chrome 浏览器。GitHub 地址:https://github.com/dtinth/puppeteer-go

package mainimport ("fmt""github.com/dtinth/puppeteer-go")func main() {browser, _ := puppeteer.Launch(puppeteer.DefaultArgs, puppeteer.Debug(false))defer browser.Close()page, _ := browser.NewPage()page.Navigate("https://www.example.com")page.Screenshot("screenshot.png")}

这两个库都提供了在 Go 中控制无头浏览器进行测试和网页操作的能力。选择其中一个库取决于你的具体需求和喜好。

三、简单实操实现登录截屏

package main
import ("context""github.com/chromedp/cdproto/cdp""github.com/chromedp/chromedp""log""os"
)
func main() {// 创建登录阶段的上下文ctxLogin, cancelLogin := chromedp.NewContext(context.Background())defer cancelLogin()// 定义变量分别用于存储两个阶段的截图var bufLogin []bytevar nodes []*cdp.Node// 登录阶段if err := chromedp.Run(ctxLogin,chromedp.Navigate("https://shimo.im/login"),//等待页面加载chromedp.WaitVisible(`[name="account"]`, chromedp.ByQuery),//输入账号和密码chromedp.SendKeys(`[name="account"]`, "zhangsan@shimo.im", chromedp.ByQuery),chromedp.SendKeys(`[name="password"]`, "woshizhangsan", chromedp.ByQuery),//点击同意协议和登录按钮chromedp.Click(`div.StyledCheckBox-sc-RjILa-1`, chromedp.ByQuery),chromedp.Click(`div[type="black"] button[data-test="btn-submit"]`, chromedp.ByQuery),//等待加载chromedp.WaitVisible(`.StyledUserCardContainer-sc-RevvT-9`, chromedp.ByQuery),chromedp.CaptureScreenshot(&bufLogin),); err != nil {log.Fatal(err)}if err := os.WriteFile("elementScreenshot.png", bufLogin, 0o644); err != nil {log.Fatal(err)}
}

chromedp使用例子:GitHub - chromedp/examples: chromedp code examples.

chromedp源码地址:GitHub - chromedp/chromedp: A faster, simpler way to drive browsers supporting the Chrome DevTools Protocol.

以下是chromedp库中常用函数:

chromedp.NewContext() 初始化chromedp的上下文,后续这个页面都使用这个上下文进行操作

chromedp.Run() 运行一个chrome的一系列操作

chromedp.Navigate() 将浏览器导航到某个页面

chromedp.WaitVisible() 等候某个元素可见,再继续执行。

chromedp.Click() 模拟鼠标点击某个元素

chromedp.Value() 获取某个元素的value值

chromedp.ActionFunc() 再当前页面执行某些自定义函数

chromedp.Text() 读取某个元素的text值

chromedp.Evaluate() 执行某个js,相当于控制台输入js

network.SetExtraHTTPHeaders() 截取请求,额外增加header头

chromedp.SendKeys() 模拟键盘操作,输入字符

chromedp.Nodes() 根据xpath获取某些元素,并存储进入数组

chromedp.NewRemoteAllocator

chromedp.OuterHTML() 获取元素的outer html

chromedp.Screenshot() 根据某个元素截图

page.CaptureScreenshot() 截取整个页面的元素

chromedp.Submit() 提交某个表单

chromedp.WaitNotPresent() 等候某个元素不存在,比如“正在搜索。。。”

chromedp.Tasks{} 一系列Action组成的任务

这篇关于【go语言】Chromeless简介及Chromedp库实现模拟登录截屏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/550295

相关文章

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

VSCode设置python SDK路径的实现步骤

《VSCode设置pythonSDK路径的实现步骤》本文主要介绍了VSCode设置pythonSDK路径的实现步骤,包括命令面板切换、settings.json配置、环境变量及虚拟环境处理,具有一定... 目录一、通过命令面板快速切换(推荐方法)二、通过 settings.json 配置(项目级/全局)三、

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性