An MCP service that automates Chrome browser control while bypassing anti-bot detection mechanisms, enabling web scraping, testing and automation on sites with sophisticated bot protection.
An MCP service built on undetected-chromedriver, providing a comprehensive interface for automating Chrome browser control while bypassing anti-bot detection.
To install MCP-Undetected-Chromedriver for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @dragons96/mcp-undetected-chromedriver --client claude
Here's the Claude Desktop configuration to use the Undetected-chromedriver server:
{ "mcpServers": { "mcp-undetected-chromedriver": { "command": "npx", "args": [ "-y", "@smithery/cli@latest", "run", "@dragons96/mcp-undetected-chromedriver", "--config", "{}" ] } } }
# Create virtual environment uv venv # Activate virtual environment # Windows .venv\Scripts\activate # Linux/MacOS source .venv/bin/activate # Install dependencies uv pip install -e .
MCP-Undetected-Chromedriver is an MCP (Multi Channel Protocol) service that wraps the functionality of the undetected-chromedriver library into a series of easy-to-use APIs. This project is particularly suitable for scenarios that require bypassing modern website anti-bot detection mechanisms in automated testing, data scraping, or web automation scripts.
mcp-server-undetected-chromedriver
The service provides the following main API interfaces:
browser_navigate
: Navigate to a specified URLbrowser_screenshot
: Take a screenshot of the current pagebrowser_click
: Click on page elementsbrowser_iframe_click
: Click on elements within an iframebrowser_fill
: Fill content in input fieldsbrowser_select
: Select options in dropdown selection boxesbrowser_hover
: Hover the mouse over elementsbrowser_evalute
: Execute JavaScript codebrowser_close
: Close the browserbrowser_get_visible_text
: Get visible text on the pagebrowser_get_visible_html
: Get visible HTML on the pagebrowser_go_back
: Navigate backward in browser historybrowser_go_forward
: Navigate forward in browser historybrowser_drag
: Drag elementsbrowser_press_key
: Simulate key pressesbrowser_save_as_pdf
: Save the page as a PDFfrom mcp.client import Client # Create MCP client client = Client() client.start("undetected-chromedriver-mcp-server") # Navigate to website response = client.call("browser_navigate", {"url": "https://example.com"}) print(response) # Take a screenshot response = client.call("browser_screenshot", {"name": "example"}) print(response) # Get page text response = client.call("browser_get_visible_text") print(response.content[0].text) # Close the browser client.call("browser_close")
This service uses the undetected-chromedriver library to create a specialized Chrome browser instance that effectively evades common anti-bot detection mechanisms. The service wraps these features through the MCP protocol, providing an easy-to-use API interface that makes automated testing and web scraping more convenient.
This project is licensed under the MIT License - see the LICENSE file for details.
Bug reports and feature requests are welcome on the GitHub Issues page. If you want to contribute code, please create an issue to discuss your ideas first.
Q: Why choose undetected-chromedriver instead of the standard selenium webdriver?
A: undetected-chromedriver is specifically designed to bypass anti-bot detection mechanisms of modern websites, such as Cloudflare, Distil Networks, etc., making it more reliable for data scraping and automated testing scenarios.
Q: How does the service handle browser instances?
A: The service maintains a global browser instance, which is automatically created when an API requiring a browser is first called. The browser can be explicitly closed using the browser_close
API.
Q: How to handle elements within iframes?
A: The browser_iframe_click
API can directly operate on elements within iframes, without the need to manually switch frame contexts.
Discover shared experiences
Shared threads will appear here, showcasing real-world applications and insights from the community. Check back soon for updates!