Browser MCP over CDP
by dumitrubogdanmihai
This project exposes tools to navigate, interact and access a browser tab using the Chrome DevTools Protocol (CDP). The server allows for full height screenshots, accessibility tree access, enriched deep DOM inspection, and browser interaction.
Last updated: N/A
Browser MCP over CDP
MCP Server that manages a Chrome browser using the Chrome DevTools Protocol (CDP)
This project exposes tools to navigate, interact and access a browser tab. The browser is controller using CDP and because of this:
- the page is exported as full height screenshoot, accessibility tree and enriched deep DOM
- the screenshoot captures whole page, not just the visible scrolled are
- the accessibility tree contains most relevand parts
- the enriched deep DOM contains
- nested iframes, shadow DOM, pseudo-elements, etc.
- per element attached listeners (for e.g. onClick, onKeyDown, etc), including the callback function code (for better or for worse)
- per element relevant resolved styles
 
 
- the page is interactable via click, keys and input value update functions
- the page is navigable with basic open URL, back, forward and reload functions
The browser is running remotely on Docker using Selenoid with VNC enabled, available at http://localhost:8080/.
Prereq
- Docker and Docker Compose
- Python
Use
- run Selenoid Selenium Hub by running the below command inside "selenoid" dir:
docker pull selenoid/vnc_chrome:128.0 docker pull selenoid/hub docker pull aerokube/selenoid-ui docker-compose up
- change absolute paths inside config-example.json and put it inside your Cloude, VS Code, Cursor, wherever you want.
- for Cloude see https://modelcontextprotocol.io/quickstart/user
- for Cursor see https://docs.cursor.com/context/model-context-protocol#configuring-mcp-servers
 
- to see the browser live open http://localhost:8080/ in your browser
- see also playground.ipynb
Warnings
The Selenoid Selenium Hub configuration uses docker.sock from the host, so it has full control over Docker.
Troubleshoot
Use https://modelcontextprotocol.io/docs/tools/inspector#python:
    npx @modelcontextprotocol/inspector uv --directory /Users/bogdan/devel/browser-mcp-over-cdp/ run src/mcp-server.py    
