Brower Opener

自动启动带远程调试端口的Chrome浏览器,支持复用Cookie或无痕模式。

已扫描
适合谁
前端开发者、Web自动化测试人员
不适合谁
普通用户日常浏览、无技术背景的非开发者
国内可用性
需网络配置。可能需要网络配置或第三方服务可访问。
安装难度
新手友好(★☆☆)。基于终端操作、依赖、API Key 和本地环境要求的初步判断。

安装与下载

openclaw skills install @luis1232023/brower-opener

Skill 说明

命令、参数、文件名以原文为准

Browser Opener - Chrome调试浏览器启动工具

概述

本技能用于启动带有远程调试端口的Chrome浏览器,支持两种模式:

  1. 复用Cookie模式(默认) - 复用主profile的登录状态和cookie
  2. 无痕/独立模式 - 使用独立profile,不保留任何会话信息

触发条件

当用户提到以下关键词时触发本技能:

触发词行为模式
打开浏览器默认复用cookie
打开测试浏览器默认复用cookie
复用cookie打开浏览器复用cookie
启动浏览器 复用cookie复用cookie
启动浏览器默认复用cookie
启动无痕浏览器独立profile模式

模式自动判断

系统根据触发词自动选择模式,无需询问用户

  • 使用独立模式的情况(以下任一):

- 用户明确提到"无痕浏览器"

- 用户明确提到"独立profile"

- 用户明确提到"不复用cookie"

  • 其他所有情况默认使用复用cookie模式

核心功能

  1. 自动环境检测

- 检测操作系统类型(Windows/macOS/Linux)

- 自动查找 Chrome 安装路径

- 自动处理端口冲突

  1. 双模式支持

- 复用模式: 复用主profile(会关闭现有Chrome窗口)

- 独立模式: 使用独立profile(无痕,不干扰现有窗口)

  1. 非阻塞启动

- 使用 subprocess.Popen 后台启动 Chrome

- 命令立即返回,不卡住智能体

- 启动完成后可直接连接 DevTools

脚本说明

本技能位于 scripts/ 目录:

脚本说明是否必需
launcher.py主脚本,跨平台统一入口,自动检测系统并启动 Chrome
health.py健康检查脚本,验证 Chrome 是否在 9222 端口正常运行(手动运行)

重要说明:

  • launcher.py 只负责启动 Chrome,不会自动运行健康检查
  • health.py 需要手动运行来验证 Chrome 是否已就绪
  • 建议在 launcher.py 启动后等待 2-3 秒,然后手动运行 health.py 确认状态

工作流程

推荐用法:使用 launcher.py + 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 independent

2. 验证 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: 打开浏览器(默认复用cookie)

用户: "打开浏览器"

执行流程:
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

场景 2: 启动无痕浏览器

用户: "启动无痕浏览器"

执行流程:
1. 检测到"无痕浏览器"触发词
2. 选择独立profile模式
3. 运行: python scripts/launcher.py --mode independent
   - 检测系统
   - 查找 Chrome 路径
   - 不关闭现有 Chrome 窗口
   - 后台启动 Chrome(使用独立profile)
   - 立即返回
4. 【可选】等待 2-3 秒后运行: python scripts/health.py
   - 验证 Chrome 是否正常响应
5. 浏览器就绪(干净的独立环境)
6. 智能体可连接 DevTools

API 使用指南

使用 launcher.py 和 health.py

import 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())
  );
}

连接到 Chrome DevTools

await chrome-devtools_navigate_page({
  type: "url",
  url: "http://127.0.0.1:9222"
});

注意事项

  1. 非阻塞启动

- launcher.py 使用 subprocess.Popen 后台启动 Chrome

- 命令立即返回,不会卡住智能体

- 启动成功后需等待 2-3 秒再连接 DevTools

  1. 健康检查(health.py)

- launcher.py 不会自动运行 health.py

- health.py 是一个独立的可选脚本,用于验证 Chrome 状态

- 建议在 launcher.py 启动后手动运行 health.py 确认状态

- 或者直接等待 2-3 秒后尝试连接 DevTools

  1. 复用cookie模式的警告

- 会关闭所有现有Chrome窗口,请提醒用户保存工作

- 复用主profile的登录状态和cookie

  1. 独立模式的特点

- 不会关闭现有Chrome窗口

- 使用全新的独立profile,无任何会话信息

- 需要重新登录网站

  1. 端口管理

- 脚本会自动处理9222端口冲突

- 如有冲突会自动关闭占用进程

  1. 安全提示

- 敏感信息应妥善处理,避免泄露

- 某些网站可能使用 HttpOnly cookie

故障排查

  1. 检查 Chrome 是否已正确启动:
   # Windows
   tasklist | findstr chrome

   # macOS/Linux
   ps aux | grep chrome
  1. 检查端口占用:
   # Windows
   netstat -ano | findstr :9222

   # macOS/Linux
   lsof -i :9222
  1. 手动验证 Chrome 调试端口:

- 访问 http://127.0.0.1:9222/json/version

- 应该返回 JSON 格式的浏览器信息

  1. 常见解决方案:

- 重启 Chrome 调试模式

- 检查防火墙设置

- 确保端口 9222 未被其他程序占用

L
@luis1232023

已收录 1 个 Skill

相关推荐