小技巧 | Get 到一个 Web 自动化方案,绝了!

1. 前言

曼易小说网 https://www.2197.info

大家好,我是安果!

无论是 Chrome,还是 Firefox 浏览器,它们的强大性在很大程度上都是依赖于海量的插件,让我们能高效办公

那我们是否可以编写一个插件,让浏览器自动化完成一些日常工作,解放双手呢?

答案是肯定的

本篇文章以 Chrome 插件为例,结合一个实例,聊聊 Web 端自动化的另一种方案

2. Chrome 插件

Chrome 扩展插件运行于基于 Chromium 内核的浏览器

包含:Chrome 浏览器、Microsoft Edge、360 浏览器等

一个 Chrome 扩展插件有 3 类文件组成,包含:

  • 配置文件 manifest.json

  • js 脚本文件

  • 图片、css 等资源文件

配置文件「 manifest.json 」用于配置扩展的名称、版本号、作者、图标 icon、弹出界面、权限、脚本路径等信息

js 脚本文件包含 popup.js、background  和 content_scripts

其中

  • popup.js 用于搭配 popup.html 使用,用于点击插件图标的时候展示页面及页面逻辑控制

  • background 用于定义一个后台页面,相当于一个常驻页面,生命周期和浏览器一致

  • content_scripts 用于注入 JS 脚本,它不会和页面中的脚本产生冲突

3. 实战一下

假设我们现在需要完成一个插件,在首次登录或登录失效时,自动完成登录操作

3-1  创建项目

我们创建一个文件夹,项目结构目录如下

3-2  项目配置

我们在 manifest.json 配置文件中,首先设置插件的基本信息

# mainifest.json

{
    "manifest_version": 2, //配置文件版本
    "name": "auto_login", //插件名称
    "version": "0.0.1", //插件版本

    //下面都是选填
    "description": "自动登录", //描述信息
    "author": "xag", //作者
    // 插件icon
    "icons": {
        "84": "./image/icon.png"
    }
...

然后,设置浏览器插件的图标及后台页面

需要注意的是,后台页面 background 可以设置一个 HTML 页面,也可以设置 JS 脚本列表,且只能选择其中一种

# mainifest.json

// 浏览器右上角的图标和内容
"browser_action": {
    "default_icon": "./image/icon.png",
    "default_title": "自动登录",
    "default_popup": "./html/popup.html" //点击插件图标,弹出来的界面
},
//后台页面,JS/HTML只能选择一种
"background": {
    "scripts": ["./js/background.js"],
    "persistent": true
},
...

接着,使用关键字「 content_scripts 」配置匹配规则及注入 JS 脚本

# mainifest.json

//content-scripts脚本设置
"content_scripts": [
    {
        // "<all_urls>" 表示匹配所有地址
        "matches": ["<all_urls>"],
        // 执行JS
        "js": ["./js/content.js"],
        "run_at": "document_end" //配置运行时间点
    },
    {
        "matches": ["https://****/"],
        "js": ["./js/content_vx.js"],
        "run_at": "document_end"
    }
],

...

这里设置所有的页面都会执行 content.js 脚本,当匹配到第二个页面时,执行 content_vx.js 脚本

需要指出的是,run_at 设置为 document_end,代表当页面加载完成后,才会执行目标脚本

最后,根据业务需要,使用关键字「 permissions 」定义权限

PS:本例不涉及权限,可以省略设置

# manifest.json

...
//权限配置
    "permissions": [
        "contextMenus", // 右键菜单
        "storage", // 本地存储
        "webRequest", // 网络请求
        "webRequestBlocking", // 阻塞式的网络请求
        "<all_urls>", // 匹配的URL
        "tabs", // 标签
        "notifications" // 通知
    ]
}

3-3  编写注入脚本

在 content_vx.js 文件中,根据需求操作 DOM 元素,完成自动化的操作

比如,这里获取用户名、密码输入框,模拟输入,然后模拟点击登录按钮,完成登录的操作

需要注意的是,如果 run_at 设置为 document_start,这里需要做延迟加载

# content_vx.js

//输入
function input(inputElement, content) {
    let evt = document.createEvent('HTMLEvents');
    evt.initEvent('input', true, true);
    inputElement.value = content;
    inputElement.dispatchEvent(evt)
}

//模拟输入和提交表单
//用户名
const username_element = document.getElementById("ContentHtml_txtUserName");
//密码
const password_element = document.getElementById("txtPassword");

//按钮
const btn_element = document.getElementById("ContentHtml_btnLogin");

//输入后,点击确认
input(username_element, "**");
input(password_element, "**");

//登录
btn_element.click();

3-4  测试使用

在定义好插件 icon 图标及 popup 页面后,我们可以进入到 Chrome 插件管理界面

开启「 开发者模式 」,然后点击左侧的「 加载已解压的扩展程序 」加载上面创建的项目文件夹

开启扩展插件,每次打开目标网站或退出登录时,会发现网页会自动完成登录操作

4. 最后

本例仅利用 content_scripts 注入一段脚本,通过操作 DOM 元素,将一个繁琐的登录操作做成自动化

实际上,复杂的 Chrome 插件会涉及到 background 配置、浮框布局 JS 脚本、inject-scripts 引入脚本及他们之间的数据传输,这部分内容大家可以自行扩展

我已经将文中所有源码上传到后台,关注公众号「 AirPython 」后回复关键字「 crx 」获取完整源码

如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Web自动化测试中切换到iframe(内嵌框架)中,您可以使用`switch_to.frame()`方法。是一个完整版的示例代码: python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC def switch_to_iframe_test(url, iframe_id, element_id): # 启动浏览器 driver = webdriver.Chrome() try: # 打开网页 driver.get(url) # 等待iframe加载完成并切换到iframe WebDriverWait(driver, 10).until(EC.frame_to_be_available_and_switch_to_it((By.ID, iframe_id))) # 找到iframe中的元素,并进行操作 element = driver.find_element_by_id(element_id) # 例如,点击元素 element.click() # 切换回默认的上下文(主页面) driver.switch_to.default_content() # 在主页面执行其他操作 # ... finally: # 关闭浏览器 driver.quit() ``` 在这个示例代码中,我们定义了一个名为`switch_to_iframe_test`的函数。该函数接受三个参数:`url`(要访问的网页URL)、`iframe_id`(要切换的iframe的id)和`element_id`(要在iframe中操作的元素的id)。 在函数内部,我们使用`webdriver.Chrome()`来实例化一个Chrome浏览器对象。然后,我们使用`driver.get(url)`打开指定的网页。 接下来,我们使用`WebDriverWait`和`EC.frame_to_be_available_and_switch_to_it()`来等待iframe加载完成并切换到iframe。在这个示例中,我们使用iframe的id来定位该iframe。 然后,我们使用`driver.find_element_by_id()`方法找到iframe中的元素,并进行相应的操作。在这个示例中,我们假设要操作的元素的id是`element_id`。 完成操作后,我们使用`driver.switch_to.default_content()`方法切换回默认的上下文(主页面)。 最后,在`finally`块中,我们使用`driver.quit()`关闭浏览器。 请注意,这只是一个简单的示例,实际的Web自动化测试可能涉及更多的操作和断言。您可以根据自己的需求修改和扩展这个函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值