Files
claude-code/docs/features/claude-in-chrome-mcp.md
unraid 6738a76152 feat: enable Claude in Chrome MCP with full browser control
Replace the 6-line stub in @ant/claude-for-chrome-mcp with the complete
implementation (8 files, 3038 lines) from the reference project.

Provides 17 browser tools: navigate, screenshot, click, type, read DOM,
execute JS, record GIF, monitor console/network, manage tabs, etc.

No feature flag needed. No changes to src/ (already matches official).

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-03 21:46:07 +08:00

9.8 KiB
Raw Blame History

Claude in Chrome MCP — 恢复计划

更新时间2026-04-03 参考项目:E:\源码\claude-code-source-main\claude-code-source-main

1. 功能概述

Claude in Chrome 让 Claude Code CLI 通过 MCP 协议控制用户的 Chrome 浏览器:导航网页、填写表单、截图、录制 GIF、读取 DOM、执行 JS、监控网络请求和控制台日志。

通信方式有两种:

  • 本地 SocketChrome 扩展通过 Native Messaging Host 与 CLI 建立 Unix socket 连接
  • Bridge WebSocket:通过 Anthropic 的 bridge 服务中转,支持远程浏览器

2. 完整加载链路

CLI 启动
  │
  ▼
src/main.tsx:1003
  .option('--chrome', 'Enable Claude in Chrome integration')
  │
  ▼
src/main.tsx:1522-1527
  setChromeFlagOverride(chromeOpts.chrome)
  │
  ▼
src/utils/claudeInChrome/setup.ts
  shouldEnableClaudeInChrome()
  ├── --chrome flag → true
  ├── --no-chrome flag → false
  ├── 非交互模式 → false
  ├── 环境变量 CLAUDE_CODE_DISABLE_CHROME → false
  ├── 配置 claudeInChromeDefaultEnabled → true/false
  └── Chrome 扩展已安装 + GrowthBook tengu_chrome_auto_enable → auto
  │
  ▼
src/utils/claudeInChrome/setup.ts
  setupClaudeInChrome()
  ├── 生成 MCP server 配置
  └── 返回 mcpConfig + allowedTools
  │
  ▼
src/utils/claudeInChrome/mcpServer.ts
  import { createClaudeForChromeMcpServer } from '@ant/claude-for-chrome-mcp'
  │
  ▼
packages/@ant/claude-for-chrome-mcp/src/index.ts  ← 当前是 STUB
  export function createClaudeForChromeMcpServer() { return null }
  export const BROWSER_TOOLS = []

3. 阻塞点清单

# 阻塞点 位置 状态
@ant/claude-for-chrome-mcp 是 stub packages/@ant/claude-for-chrome-mcp/src/index.ts 6 行空壳,返回 null
缺少完整实现7 个文件3038 行) packages/@ant/claude-for-chrome-mcp/src/ 只有 1 个 stub 文件

不需要任何 feature flag/chrome 命令无条件注册在 src/commands.ts:264

不需要改 src/ 下任何文件 — 以下文件全部与参考项目 0 行差异:

  • src/utils/claudeInChrome/setup.ts
  • src/utils/claudeInChrome/mcpServer.ts
  • src/utils/claudeInChrome/common.ts
  • src/utils/claudeInChrome/chromeNativeHost.ts
  • src/utils/claudeInChrome/prompt.ts
  • src/utils/claudeInChrome/setupPortable.ts
  • src/utils/claudeInChrome/toolRendering.tsx
  • src/commands/chrome/index.ts
  • src/commands/chrome/chrome.tsx(仅 sourcemap 差异)
  • src/skills/bundled/claudeInChrome.ts

4. 参考项目完整实现清单

参考项目路径:deps/@ant/claude-for-chrome-mcp/src/

文件 行数 职责
index.ts 15 导出入口:createBridgeClientBROWSER_TOOLScreateChromeSocketClientcreateClaudeForChromeMcpServerlocalPlatformLabel + 类型导出
types.ts 134 类型定义:LoggerPermissionModeBridgeConfigChromeExtensionInfoClaudeForChromeContextSocketClientBridgePermissionRequest/ResponsePermissionOverrides
browserTools.ts 546 17 个浏览器工具定义MCP tool schema
mcpServer.ts 96 MCP Server 创建:注册 ListTools/CallTool handler选择 socket/bridge 传输
mcpSocketClient.ts 493 Unix Socket 客户端:连接 Chrome Native Messaging HostJSON-RPC 通信
mcpSocketPool.ts 327 Socket 连接池:多 Chrome profile 支持,按 tabId 路由
bridgeClient.ts 1126 Bridge WebSocket 客户端:连接 Anthropic bridge 服务,扩展发现、设备配对、权限管理
toolCalls.ts 301 工具调用路由:连接状态处理、结果转换、权限模式切换、浏览器切换

17 个浏览器工具

工具名 功能
javascript_tool 在页面上下文执行 JavaScript
read_page 获取页面可访问性树DOM
find 自然语言搜索页面元素
form_input 填写表单字段
computer 鼠标键盘操作 + 截图13 种 action
navigate URL 导航 / 前进后退
resize_window 调整浏览器窗口尺寸
gif_creator GIF 录制和导出
upload_image 图片上传到文件输入框或拖拽区域
get_page_text 提取页面纯文本
tabs_context_mcp 获取当前标签组信息
tabs_create_mcp 创建新标签页
update_plan 向用户提交操作计划供审批
read_console_messages 读取浏览器控制台日志
read_network_requests 读取网络请求
shortcuts_list 列出可用快捷方式
shortcuts_execute 执行快捷方式
switch_browser 切换到其他 Chrome 浏览器(仅 bridge 模式)

外部依赖

依赖 用途 我们项目是否已有
ws WebSocket 客户端bridge 模式)
@modelcontextprotocol/sdk MCP Server + 类型
fs/net/os/path Node.js 内置

5. 修复步骤

步骤 1复制完整实现到 stub 包目录

# 从参考项目复制 7 个文件(覆盖现有的 1 个 stub
cp "E:/源码/claude-code-source-main/claude-code-source-main/deps/@ant/claude-for-chrome-mcp/src/"*.ts \
   "E:/源码/Claude-code-bast/packages/@ant/claude-for-chrome-mcp/src/"

复制后 packages/@ant/claude-for-chrome-mcp/src/ 应包含 8 个文件:

packages/@ant/claude-for-chrome-mcp/src/
├── index.ts           ← 覆盖 stub15 行,导出入口)
├── types.ts           ← 新增134 行)
├── browserTools.ts    ← 新增546 行)
├── mcpServer.ts       ← 新增96 行)
├── mcpSocketClient.ts ← 新增493 行)
├── mcpSocketPool.ts   ← 新增327 行)
├── bridgeClient.ts    ← 新增1126 行)
└── toolCalls.ts       ← 新增301 行)

步骤 2验证构建

bun run build

不需要改 scripts/dev.tsbuild.ts(无 feature flag

步骤 3功能验证

# 启动(手动启用 chrome
bun run dev -- --chrome

# 在 REPL 中:
# 1. /chrome 命令应显示 Chrome 设置菜单
# 2. 如果 Chrome 扩展已安装 → 状态显示 "Enabled"
# 3. 如果未安装 → 提示安装扩展链接

6. 验证测试项

6.1 构建验证

测试项 预期结果 验证命令
build 成功 无报错 bun run build
BROWSER_TOOLS 非空 产物中包含 17 个工具定义 grep "javascript_tool" dist/*.js
createClaudeForChromeMcpServer 非 null 产物中包含 MCP Server 创建逻辑 grep "ListToolsRequestSchema" dist/*.js
Bridge WebSocket 逻辑在产物中 包含 bridge 连接代码 grep "bridge.claudeusercontent.com" dist/*.js

6.2 命令注册验证

测试项 预期结果
/chrome 命令可见 REPL 中输入 /chrome 显示设置菜单
--chrome 参数可用 bun run dev -- --chrome 不报错
--no-chrome 参数可用 bun run dev -- --no-chrome 不报错

6.3 MCP Server 验证(需要 Chrome 扩展)

测试项 预期结果
Chrome 扩展检测 已安装扩展时 /chrome 显示 "Extension: Installed"
Socket 连接 扩展连接后 MCP tools 可用
BROWSER_TOOLS 注册 tabs_context_mcp 等 17 个工具在 MCP 工具列表中可见

6.4 工具功能验证(需要 Chrome 扩展 + 连接)

测试项 预期结果
tabs_context_mcp 返回当前标签组信息
navigate 能导航到指定 URL
computer + screenshot 返回页面截图
read_page 返回 DOM 可访问性树
javascript_tool 执行 JS 并返回结果

6.5 不影响现有功能

测试项 预期结果
不带 --chrome 启动 正常运行,无 chrome 相关报错
/voice 命令 不受影响
/schedule 命令 不受影响
bun test 现有测试全部通过

7. 改动总结

操作 文件 说明
覆盖 stub packages/@ant/claude-for-chrome-mcp/src/index.ts 6 行 stub → 15 行完整导出
新增 packages/@ant/claude-for-chrome-mcp/src/types.ts 134 行类型定义
新增 packages/@ant/claude-for-chrome-mcp/src/browserTools.ts 546 行17 个工具定义
新增 packages/@ant/claude-for-chrome-mcp/src/mcpServer.ts 96 行 MCP Server
新增 packages/@ant/claude-for-chrome-mcp/src/mcpSocketClient.ts 493 行 Socket 客户端
新增 packages/@ant/claude-for-chrome-mcp/src/mcpSocketPool.ts 327 行连接池
新增 packages/@ant/claude-for-chrome-mcp/src/bridgeClient.ts 1126 行 Bridge 客户端
新增 packages/@ant/claude-for-chrome-mcp/src/toolCalls.ts 301 行工具调用路由

不改动src/ 下所有文件(已与参考项目一致)、scripts/dev.tsbuild.ts

8. 运行时依赖

依赖 必需? 说明
Chrome 浏览器 需安装 Chrome
Claude in Chrome 扩展 https://claude.ai/chrome 安装
claude.ai OAuth 登录 Bridge 模式需要 本地 Socket 模式不需要
Native Messaging Host 本地 Socket 需要 扩展安装时自动注册

9. 与 /voice、/schedule 恢复方式对比

/schedule /voice Claude in Chrome
编译开关 AGENT_TRIGGERS_REMOTE VOICE_MODE 无需
改 dev.ts/build.ts 不需要
缺失的 vendor 二进制 .node 文件
需要替换的 stub audio-capture-napi @ant/claude-for-chrome-mcp7 个文件)
改动 src/ 源码
平台限制 需原生 .node 需 Chrome 浏览器