Browser MCP Bridge
Claude Codeにブラウザへの直接アクセス権を与えます。自然言語を通じて、ページの検査、コンソールエラーの読み取り、ネットワークリクエストの監視、スクリーンショットのキャプチャ、JavaScriptの実行が可能です。
このツールの機能
Browser MCP Bridgeは、Model Context Protocol (MCP) を介してChromeブラウザをClaude Codeに接続します。以下の2つのパーツで構成されています。
Chrome拡張機能: ブラウザデータ(ページコンテンツ、DOM、コンソール、ネットワーク、パフォーマンス、アクセシビリティ)をキャプチャします。
MCPサーバー: 11種類の専用ツールを通じて、そのデータをClaude Codeに公開します。
接続が完了すると、Claude Codeに対して以下のような指示が可能になります:
「このページのアクセシビリティの問題をチェックして」
「このページで発生しているコンソールエラーは何?」
「失敗したAPIリクエストを見せて」
「このページのパフォーマンスを分析して」
「現在のページで
document.querySelectorAll('a')を実行して」
Related MCP server: Browser Agent MCP
クイックスタート
5分以内にセットアップを完了しましょう:
1. サーバーのインストール
git clone https://github.com/anthropics/browser-mcp-bridge.git
cd browser-mcp-bridge
npm run install-server2. ブラウザ拡張機能のインストール
chrome://extensions/(またはedge://extensions/)を開きます。デベロッパーモード(右上のトグル)を有効にします。
パッケージ化されていない拡張機能を読み込むをクリックします。
このリポジトリの
extension/ディレクトリを選択します。
ツールバーに「Browser MCP Bridge」アイコンが表示されるはずです。
3. Claude Codeの設定
claude mcp add --scope user --transport http browser-mcp http://127.0.0.1:6009/mcp4. サーバーの起動と接続
npm start次に、Browser MCP Bridge拡張機能のアイコンをクリックし、Connectをクリックします。ステータスインジケーターが緑色に変わるはずです。
これで完了です。Claude Codeがブラウザにアクセスできるようになりました。
プロジェクト構造
browser-mcp-bridge/
├── extension/ # Chrome extension
│ ├── manifest.json # Manifest V3 configuration
│ ├── background.js # Service worker (WebSocket, tab management)
│ ├── content.js # Content script (page data extraction)
│ ├── inject.js # Injected script (console/network interception)
│ ├── popup.html/js # Extension popup (connection management)
│ ├── devtools.html/js # DevTools integration entry point
│ ├── panel.html/js # Custom DevTools panel UI
│ └── icons/ # Extension icons
├── server/ # Node.js MCP server
│ ├── server.js # HTTP MCP server + WebSocket server
│ └── package.json # Server dependencies
├── rust-server/ # Rust MCP server (experimental)
│ ├── src/ # Rust source code
│ ├── Cargo.toml # Rust dependencies
│ └── config.toml # Server configuration
├── browser-mcp-rust-server.service # systemd user service unit
├── install-rust-service.sh # Service install/uninstall script
├── start-rust-server.sh # PM2 launch script for Rust server
├── ecosystem.config.cjs # PM2 process manager config
├── ARCHITECTURE.md # System architecture documentation
├── API_REFERENCE.md # Complete MCP tools reference
├── DATA_OPTIMIZATION.md # Data filtering and pagination guide
└── package.json # Root scripts and orchestration仕組み
┌─────────────────┐ WebSocket ┌──────────────────┐ HTTP/MCP ┌─────────────────┐
│ Chrome Extension │ ◄──────────────── │ MCP Server │ ◄──────────────── │ Claude Code │
│ │ ws://localhost │ (port 6009) │ http://localhost │ (one or more │
│ • content.js │ :6009/ws │ │ :6009/mcp │ instances) │
│ • background.js │ ─────────────────►│ • 11 MCP tools │ ─────────────────►│ │
│ • inject.js │ │ • Resources │ │ │
│ • DevTools │ │ • Data filtering│ │ │
└─────────────────┘ └──────────────────┘ └─────────────────┘拡張機能がコンテンツスクリプトとChrome APIを介してブラウザデータをキャプチャします。
WebSocket接続がデータをポート6009のMCPサーバーに送信します。
Claude Codeが
/mcpのHTTPトランスポート経由でサーバーに接続します。複数のClaude Codeインスタンスが同じサーバーを共有できます。
利用可能なツール
ツール | 説明 |
| ページのテキスト、HTML、メタデータを抽出 |
| 構造化されたDOMツリーを取得(CSSセレクターでフィルタリング可能) |
| ページコンテキストでJavaScriptを実行 |
| コンソールログ、エラー、警告を読み取り |
| HTTPリクエストとレスポンスを検査 |
| タブの視覚的なスナップショットを撮影 |
| 読み込み時間とCore Web Vitalsを取得 |
| アクセシビリティツリーを取得 |
| 開いているすべてのブラウザタブを一覧表示 |
| Chrome DevToolsデバッガーをタブにアタッチ |
| タブからデバッガーをデタッチ |
すべてのツールは、特定のタブをターゲットにするためのオプションの tabId パラメーターをサポートしています。完全なパラメータードキュメントについては API_REFERENCE.md を参照してください。
ワークフロー例
コンソールエラーのデバッグ
Claude Codeにこう尋ねます:「ブラウザコンソールに表示されているエラーは何ですか?」
Claude Codeは get_console_messages を使用してエラーや警告を取得し、それらを分析して修正案を提示します。
失敗したAPI呼び出しの分析
こう尋ねます:「失敗したネットワークリクエストを見せて、デバッグを手伝って」
Claude Codeは失敗のみをフィルタリングする get_network_requests を使用して4xx/5xxレスポンスを見つけ、リクエスト/レスポンスボディを検査して手がかりを探します。
アクセシビリティ監査
こう尋ねます:「このページのアクセシビリティの問題をチェックして」
Claude Codeは get_accessibility_tree と get_page_content を呼び出し、ARIA属性、見出し構造、altテキスト、セマンティックHTMLを分析します。
パフォーマンス分析
こう尋ねます:「このページのパフォーマンスはどうですか?何か問題はありますか?」
get_performance_metrics と get_network_requests を使用して、遅いリソース、大きなペイロード、Core Web Vitalsの問題を特定します。
視覚的な検査
こう尋ねます:「現在のページのスクリーンショットを撮って」
capture_screenshot が表示されているタブのPNGまたはJPEGスナップショットを返します。
設定
サーバーポート
サーバーのデフォルトポートは 6009 です。別のポートを使用する場合:
MCP_SERVER_PORT=8080 npm startポートを変更した場合は、ポップアップ内の拡張機能のWebSocket URL(ws://localhost:8080/ws)と、Claude CodeのMCP設定を更新してください。
拡張機能の設定
拡張機能アイコンをクリックして以下を行います:
接続ステータスの表示
WebSocketサーバーURLの変更
手動でのデータキャプチャのトリガー
メッセージ統計の表示
PM2での実行(本番環境)
# Start with PM2
npm run pm2:start
# Other PM2 commands
npm run pm2:status # Check status
npm run pm2:logs # View logs
npm run pm2:restart # Restart
npm run pm2:stop # Stop起動時の自動開始や高度な設定については PM2_GUIDE.md を参照してください。
systemdを使用したRustサーバーの実行(Linux)
Rustサーバーは、自動起動とプロセス監視のためにsystemdユーザーサービスとして管理できます。
クイックセットアップ:
# Build and install the service in one step
./install-rust-service.sh
# Or install without rebuilding (if you already have a release binary)
./install-rust-service.sh --no-buildサービスの管理:
systemctl --user status browser-mcp-rust-server # Check status
journalctl --user -u browser-mcp-rust-server -f # Follow logs
systemctl --user restart browser-mcp-rust-server # Restart
systemctl --user stop browser-mcp-rust-server # Stopサービスはログイン時に自動開始されます。ログインセッションなしでも開始するには(ヘッドレス/SSHアクセスに便利):
loginctl enable-linger $USERアンインストール:
./install-rust-service.sh --uninstall手動インストール(スクリプトを使用したくない場合):
# Build the release binary
cd rust-server && cargo build --release
# Copy the service file
mkdir -p ~/.config/systemd/user
cp browser-mcp-rust-server.service ~/.config/systemd/user/
# If your repo is NOT at ~/dev/browser-mcp-bridge, edit the paths:
# systemctl --user edit browser-mcp-rust-server
# and override ExecStart and WorkingDirectory
# Enable and start
systemctl --user daemon-reload
systemctl --user enable --now browser-mcp-rust-server設定:
サービスはデフォルトで rust-server/config.toml を読み取ります。ポートやその他の設定を変更するには、config.toml を編集して再起動します:
systemctl --user restart browser-mcp-rust-serverログの詳細度を設定するには RUST_LOG を使用します。デフォルトは info です。ドロップインファイルで上書きします:
systemctl --user edit browser-mcp-rust-server[Service]
Environment=RUST_LOG=debug他のクライアント向けのMCP設定
JSON設定を使用するMCPクライアントの場合:
{
"mcpServers": {
"browser-mcp": {
"url": "http://localhost:6009/mcp"
}
}
}開発
サーバー開発
npm run dev # Start with --watch (auto-restart on changes)
DEBUG=* npm start # Verbose logging拡張機能開発
extension/内のファイルを変更します。chrome://extensions/に移動します。Browser MCP Bridge拡張機能の再読み込みボタンをクリックします。
ヘルスチェック
npm run health-check
# or: curl http://localhost:6009/health新しいツールの追加
server.jsのListToolsRequestSchemaハンドラーにツール定義を追加します。server.jsのCallToolRequestSchemaハンドラーにツールロジックを実装します。extension/background.jsにブラウザ側のハンドラーを追加します。Claude Codeでテストします。
データ最適化
サーバーは、AIエージェントが扱いやすいようにインテリジェントなデフォルト値を実装しています:
HTML: 50KBで切り捨て(テキストは30KB)
DOM: 500ノードに制限、スクリプト/スタイルは除外
コンソール: デフォルトでエラーと警告を返します
ネットワーク: 50リクエスト、失敗したリクエストを優先、ボディは除外
すべての制限はリクエストごとに設定可能です。フィルタリング、ページネーション、最適化ガイドの詳細は DATA_OPTIMIZATION.md を参照してください。
トラブルシューティング
拡張機能が接続されない
サーバーが実行されているか確認します:
curl http://localhost:6009/health拡張機能ポップアップのWebSocket URLがサーバーポートと一致しているか確認します。
ブラウザコンソールでエラーを確認します(
chrome://extensions/→ エラーリンク)
Claude Codeがツールを見つけられない
MCP設定を確認します:
claude mcp listサーバーが実行中で正常であることを確認します。
サーバーを再追加します:
claude mcp remove browser-mcp && claude mcp add --scope user --transport http browser-mcp http://127.0.0.1:6009/mcp
ツールからデータが返されない
拡張機能が接続されていることを確認します(ポップアップで緑色のステータス)
ブラウザでページに移動します — 拡張機能にはアクティブなページが必要です。
タブIDが正しいか確認します(先に
get_browser_tabsを使用してください)
サーバーが起動しない
Node.jsのバージョンを確認します:
node --version(18.0.0以上が必要です)依存関係をインストールします:
npm run install-serverポート6009が使用中か確認します:
lsof -i :6009
詳細情報
ARCHITECTURE.md — システム設計、データフロー、コンポーネントの詳細
API_REFERENCE.md — すべてのパラメーターを含む完全なMCPツールリファレンス
DATA_OPTIMIZATION.md — フィルタリング、ページネーション、パフォーマンスチューニング
要件
Node.js 18.0.0+
Chrome、Edge、またはChromiumベースのブラウザ
Claude Code CLI(またはMCP互換クライアント)
ライセンス
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/robhicks/browser-mcp-bridge'
If you have feedback or need assistance with the MCP directory API, please join our Discord server
