我的GitHub
0%

无星的自动化之旅(七)——PlayWright加载插件

背景

使用playwright启动的是为一个无痕浏览器

但是我们有时候需要包含一些浏览器拓展

如何找到拓展安装地址

我这里以Edge为例,其他浏览器自己搜

1
C:\Users\user_name\AppData\Local\Microsoft\Edge\User Data\Default\Extensions

所有插件都在其中

可以根据拓展中展示的插件id知道插件名称

使用说明

在当前项目下新建一个extensions文件夹

将拓展id文件夹放置其中

例如

1
playwrightDemo\extensions\mcohilncbfahbmgdjkbpemcciiolgcge\3.41.0_0

创建browser工具类

还要在当前项目下新建一个userData文件夹存放持久化数据

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
// 浏览器工具

const { chromium } = require('playwright');
const path = require('path');
const fs = require('fs-extra');
// 拓展地址和工具

// 提取拓展地址
const getExtensionsPath = () => {
const extensionPath = path.join(__dirname, '../extensions');
const extensionIds = [
'mcohilncbfahbmgdjkbpemcciiolgcge',
];
// 拼接路径
const EXTENSION_PATHS = extensionIds.map(id => path.join(extensionPath, id));
const extensions = EXTENSION_PATHS.map(p => getLatestExtensionDir(p)).join(',');
return extensions;
}
// 获取拓展id下的最新版本
const getLatestExtensionDir = (basePath) => {
const versionDirs = fs.readdirSync(basePath)
.filter(f => fs.statSync(path.join(basePath, f)).isDirectory())
.sort((a, b) => {
const [v1] = a.split('_');
const [v2] = b.split('_');
return v2.localeCompare(v1, undefined, { numeric: true });
});
return path.join(basePath, versionDirs[0]);
}

// 用户数据地址
const getUserDataDir = (userIndex = '0') => {
const userDataDir = path.join(__dirname, '../userData', userIndex);
return userDataDir;
}

// 创建持久化浏览器
const createBrowser = async (proxyIndex) => {
const extensionPath = getExtensionsPath();
const userDataDir = getUserDataDir();
const browserContext = await chromium.launchPersistentContext(userDataDir, {
headless: false,
args: [
`--disable-extensions-except=${extensionPath}`,
`--load-extension=${extensionPath}`,
],
});
return browserContext;
}

module.exports = {
createBrowser,
getUserDataDir,
}

好了,你的插件就可以成功加载

我是阿星,阿星的阿,阿星的星!