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、监控网络请求和控制台日志。
通信方式有两种:
- 本地 Socket:Chrome 扩展通过 Native Messaging Host 与 CLI 建立 Unix socket 连接
- Bridge WebSocket:通过 Anthropic 的 bridge 服务中转,支持远程浏览器
2. 完整加载链路
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 |
导出入口:createBridgeClient、BROWSER_TOOLS、createChromeSocketClient、createClaudeForChromeMcpServer、localPlatformLabel + 类型导出 |
types.ts |
134 |
类型定义:Logger、PermissionMode、BridgeConfig、ChromeExtensionInfo、ClaudeForChromeContext、SocketClient、BridgePermissionRequest/Response、PermissionOverrides |
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 Host,JSON-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 包目录
复制后 packages/@ant/claude-for-chrome-mcp/src/ 应包含 8 个文件:
步骤 2:验证构建
不需要改 scripts/dev.ts 或 build.ts(无 feature flag)。
步骤 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.ts、build.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-mcp(7 个文件) |
| 改动 src/ 源码 |
无 |
无 |
无 |
| 平台限制 |
无 |
需原生 .node |
需 Chrome 浏览器 |