【自动化】WebUI自动化通过读取用户数据的方式启动浏览器实现绕过相关登录验证的方法。

背景说明

我相信做自动化测试或者实现UI自动化相关功能的同学肯定碰到过,每次写好脚本执行时都是默认打开一个 "新"的浏览器,我的意思是就跟刚下载的浏览器一样。而不是平时日常使用着的浏览器的状态,日常使用浏览器时只要近期登录过,那么不久再打开是不需要重新登录的。(我这只是简单举例讲下背景)

举例说明--使用Playwright的实践方法

使用 Playwright 和 Python 来实现通过指定用户数据目录启动浏览器的功能,可以避免每次执行脚本时都需要重新登录和复杂验证。

以下是详细步骤和示例代码

1. 先手动启动浏览器并登录

首先,手动启动浏览器并登录需要的账号,完成所有必要的验证,然后关闭浏览器。用户数据目录通常位于以下位置:

Windows: C:\Users\<YourUsername>\AppData\Local\Google\Chrome\User Data

macOS: /Users/<YourUsername>/Library/Application Support/Google/Chrome

Linux: /home/<YourUsername>/.config/google-chrome

2. 使用 Playwright 指定用户数据目录启动浏览器

以下是使用 Python 和 Playwright 的示例代码,用于启动一个带有指定用户数据目录的浏览器会话:

python 复制代码
from playwright.sync_api import sync_playwright

def run(playwright):
    # 指定用户数据目录路径
    user_data_dir = '/path/to/your/chrome/user/data'
    
    # 启动浏览器并指定用户数据目录
    browser = playwright.chromium.launch_persistent_context(user_data_dir, headless=False)

    # 打开新页面
    page = browser.new_page()

    # 导航到目标网站
    page.goto('https://example.com')

    # 你可以在这里继续你的自动化操作

    # 关闭浏览器
    # browser.close() # 持续会话不建议每次关闭,除非有特殊需要

with sync_playwright() as playwright:
    run(playwright)

执行脚本,你就会发现这次直接打开的浏览器是携带前面手动登录后的登录状态的了~

那么除了playwright外,用selenium也是差不多意思,可以实践实践看看~

注意事项

用户数据目录: 确保路径正确,并且你的脚本有权限读取该目录。

浏览器兼容性: 不同浏览器的用户数据目录路径可能不同,上述示例适用于 Chromium 和 Chrome。

如果使用 Firefox 或 WebKit,路径可能会有所不同。

浏览器版本: 确保你手动操作时使用的浏览器版本与 Playwright 使用的版本一致,以避免兼容性问题。

通过这种方式,你可以在启动浏览器时保留之前的会话信息,包括已登录的账号状态,从而避免每次脚本执行都需要重新登录的复杂验证过程。

相关推荐
玉梅小洋10 小时前
Windows 10 Android 构建配置指南
android·windows
可可南木10 小时前
3070文件格式--15--bootptab文件
功能测试·测试工具·pcb工艺
生而为虫16 小时前
Selenium打开网页时保持登陆状态
selenium·测试工具
雨中风华16 小时前
Linux, macOS系统实现远程目录访问(等同于windows平台xFsRedir软件的目录重定向)
linux·windows·macos
Yeats_Liao16 小时前
评估体系构建:基于自动化指标与人工打分的双重验证
运维·人工智能·深度学习·算法·机器学习·自动化
好好学习天天向上~~17 小时前
6_Linux学习总结_自动化构建
linux·学习·自动化
yuuki23323318 小时前
【C++】继承
开发语言·c++·windows
非凡ghost18 小时前
PowerDirector安卓版(威力导演安卓版)
android·windows·学习·软件需求
骆驼爱记录19 小时前
Word样式检查器使用指南
自动化·word·excel·wps·新人首发
daad77720 小时前
tcpdump_BPF
linux·测试工具·tcpdump