Config Validator
验证 OpenClaw 配置字段与值的正确性,提供官方 schema 参考和示例。
自动启动带远程调试端口的Chrome浏览器,支持复用Cookie或无痕模式。
openclaw skills install @luis1232023/brower-opener命令、参数、文件名以原文为准
本技能用于启动带有远程调试端口的Chrome浏览器,支持两种模式:
当用户提到以下关键词时触发本技能:
| 触发词 | 行为模式 |
|---|---|
| 打开浏览器 | 默认复用cookie |
| 打开测试浏览器 | 默认复用cookie |
| 复用cookie打开浏览器 | 复用cookie |
| 启动浏览器 复用cookie | 复用cookie |
| 启动浏览器 | 默认复用cookie |
| 启动无痕浏览器 | 独立profile模式 |
系统根据触发词自动选择模式,无需询问用户:
- 用户明确提到"无痕浏览器"
- 用户明确提到"独立profile"
- 用户明确提到"不复用cookie"
- 检测操作系统类型(Windows/macOS/Linux)
- 自动查找 Chrome 安装路径
- 自动处理端口冲突
- 复用模式: 复用主profile(会关闭现有Chrome窗口)
- 独立模式: 使用独立profile(无痕,不干扰现有窗口)
- 使用 subprocess.Popen 后台启动 Chrome
- 命令立即返回,不卡住智能体
- 启动完成后可直接连接 DevTools
本技能位于 scripts/ 目录:
| 脚本 | 说明 | 是否必需 |
|---|---|---|
launcher.py | 主脚本,跨平台统一入口,自动检测系统并启动 Chrome | 是 |
health.py | 健康检查脚本,验证 Chrome 是否在 9222 端口正常运行 | 否(手动运行) |
重要说明:
launcher.py 只负责启动 Chrome,不会自动运行健康检查health.py 需要手动运行来验证 Chrome 是否已就绪launcher.py 启动后等待 2-3 秒,然后手动运行 health.py 确认状态完整工作流程:
1. 解析用户请求,检测触发关键词
↓
2. 判断是否使用独立模式
├─ 触发词包含"无痕"/"独立profile"/"不复用" → 使用 --mode independent
└─ 其他情况 → 使用 --mode reuse(默认)
↓
3. 运行 launcher.py 启动 Chrome
├─ 自动检测操作系统类型
├─ 查找 Chrome 安装路径
├─ 关闭占用 9222 端口的进程
├─ 后台启动 Chrome(非阻塞)
└─ 立即返回成功状态
↓
4. 【可选】等待 2-3 秒后运行 health.py 验证状态
└─ 确认 Chrome 是否在 9222 端口正常运行
↓
5. 浏览器就绪,可以连接到 Chrome DevTools (http://127.0.0.1:9222)1. 启动 Chrome(必需):
# 复用主profile(默认)
python scripts/launcher.py
# 或明确指定
python scripts/launcher.py --mode reuse
# 独立profile(无痕模式)
python scripts/launcher.py --mode independent2. 验证 Chrome 状态(可选但推荐):
# 在 launcher.py 启动后运行(等待 2-3 秒)
python scripts/health.py输出示例:
Checking Chrome health on port 9222...
[OK] Chrome is healthy and responding on port 9222用户: "打开浏览器"
执行流程:
1. 检测到"打开浏览器"触发词(非无痕模式)
2. 选择复用cookie模式
3. 运行: python scripts/launcher.py --mode reuse
- 检测系统(Windows/macOS/Linux)
- 查找 Chrome 路径
- 关闭现有 Chrome 窗口
- 后台启动 Chrome
- 立即返回
4. 【可选】等待 2-3 秒后运行: python scripts/health.py
- 验证 Chrome 是否正常响应
5. 浏览器就绪(保持登录状态)
6. 智能体可连接 DevTools用户: "启动无痕浏览器"
执行流程:
1. 检测到"无痕浏览器"触发词
2. 选择独立profile模式
3. 运行: python scripts/launcher.py --mode independent
- 检测系统
- 查找 Chrome 路径
- 不关闭现有 Chrome 窗口
- 后台启动 Chrome(使用独立profile)
- 立即返回
4. 【可选】等待 2-3 秒后运行: python scripts/health.py
- 验证 Chrome 是否正常响应
5. 浏览器就绪(干净的独立环境)
6. 智能体可连接 DevToolsimport subprocess
import time
# 步骤 1: 启动 Chrome
# 复用主profile(默认)
subprocess.run(["python", "scripts/launcher.py"])
# 或独立profile模式
# subprocess.run(["python", "scripts/launcher.py", "--mode", "independent"])
# 步骤 2: 【推荐】等待 Chrome 启动完成
time.sleep(3)
# 步骤 3: 【可选】运行健康检查验证状态
result = subprocess.run(["python", "scripts/health.py"], capture_output=True, text=True)
print(result.stdout)const isWindows = process.platform === 'win32';
const isMacOS = process.platform === 'darwin';
const isLinux = process.platform === 'linux';function shouldUseIndependentMode(userInput) {
const independentKeywords = ['无痕', '独立profile', '不复用', 'incognito'];
return independentKeywords.some(keyword =>
userInput.toLowerCase().includes(keyword.toLowerCase())
);
}await chrome-devtools_navigate_page({
type: "url",
url: "http://127.0.0.1:9222"
}); - launcher.py 使用 subprocess.Popen 后台启动 Chrome
- 命令立即返回,不会卡住智能体
- 启动成功后需等待 2-3 秒再连接 DevTools
- launcher.py 不会自动运行 health.py
- health.py 是一个独立的可选脚本,用于验证 Chrome 状态
- 建议在 launcher.py 启动后手动运行 health.py 确认状态
- 或者直接等待 2-3 秒后尝试连接 DevTools
- 会关闭所有现有Chrome窗口,请提醒用户保存工作
- 复用主profile的登录状态和cookie
- 不会关闭现有Chrome窗口
- 使用全新的独立profile,无任何会话信息
- 需要重新登录网站
- 脚本会自动处理9222端口冲突
- 如有冲突会自动关闭占用进程
- 敏感信息应妥善处理,避免泄露
- 某些网站可能使用 HttpOnly cookie
# Windows
tasklist | findstr chrome
# macOS/Linux
ps aux | grep chrome # Windows
netstat -ano | findstr :9222
# macOS/Linux
lsof -i :9222- 访问 http://127.0.0.1:9222/json/version
- 应该返回 JSON 格式的浏览器信息
- 重启 Chrome 调试模式
- 检查防火墙设置
- 确保端口 9222 未被其他程序占用
已收录 1 个 Skill