Shows integration with GitHub for storing and displaying image assets, as demonstrated by the example screenshot in the README
Supports capturing screenshots in JPEG format with configurable quality settings
Supports Linux platforms with browser detection for Chrome and Chromium through system commands
Offers platform-specific browser detection for macOS, including Chrome, Edge, and Safari browsers
Provides installation through npm package registry, supporting both global and local installation options
Uses Puppeteer to capture screenshots of webpages, supporting full page or specific element captures with customizable options for viewport size, image quality, and formats
Detects and can use Safari as a default browser option on macOS for screenshot capture workflows
Webpage Screenshot MCP Server
An MCP (Model Context Protocol) server that captures screenshots of web pages using Puppeteer. This server allows AI agents to visually verify web applications and see their progress when generating web apps.
Features
- Full page screenshots: Capture entire web pages or just the viewport
- Element screenshots: Target specific elements using CSS selectors
- Multiple formats: Support for PNG, JPEG, and WebP formats
- Customizable options: Set viewport size, image quality, wait conditions, and delays
- Base64 encoding: Returns screenshots as base64 encoded images for easy integration
- Authentication support: Manual login and cookie persistence
- Default browser integration: Use your system's default browser for a more natural experience
- Session persistence: Keep browser sessions open for multi-step workflows
Installation
Usage
Tools
This MCP server provides several tools:
1. login-and-wait
Opens a webpage in a visible browser window for manual login, waits for user to complete login, then saves cookies.
url
(required): The URL of the login pagewaitMinutes
(optional): Maximum minutes to wait for login (default: 5)successIndicator
(optional): CSS selector or URL pattern that indicates successful loginuseDefaultBrowser
(optional): Whether to use the system's default browser (default: true)
2. screenshot-page
Captures a screenshot of a given URL and returns it as base64 encoded image.
url
(required): The URL of the webpage to screenshotfullPage
(optional): Whether to capture the full page or just the viewport (default: true)width
(optional): Viewport width in pixels (default: 1920)height
(optional): Viewport height in pixels (default: 1080)format
(optional): Image format - "png", "jpeg", or "webp" (default: "png")quality
(optional): Quality of the image (0-100), only applicable for jpeg and webpwaitFor
(optional): When to consider page loaded - "load", "domcontentloaded", "networkidle0", or "networkidle2" (default: "networkidle2")delay
(optional): Additional delay in milliseconds after page load (default: 0)useSavedAuth
(optional): Whether to use saved cookies from previous login (default: true)reuseAuthPage
(optional): Whether to use the existing authenticated page (default: false)useDefaultBrowser
(optional): Whether to use the system's default browser (default: false)visibleBrowser
(optional): Whether to show the browser window (default: false)
3. screenshot-element
Captures a screenshot of a specific element on a webpage using a CSS selector.
url
(required): The URL of the webpageselector
(required): CSS selector for the element to screenshotwaitForSelector
(optional): Whether to wait for the selector to appear (default: true)format
(optional): Image format - "png", "jpeg", or "webp" (default: "png")quality
(optional): Quality of the image (0-100), only applicable for jpeg and webppadding
(optional): Padding around the element in pixels (default: 0)useSavedAuth
(optional): Whether to use saved cookies from previous login (default: true)useDefaultBrowser
(optional): Whether to use the system's default browser (default: false)visibleBrowser
(optional): Whether to show the browser window (default: false)
4. clear-auth-cookies
Clears saved authentication cookies for a specific domain or all domains.
url
(optional): URL of the domain to clear cookies for. If not provided, clears all cookies.
Default Browser Mode
The default browser mode allows you to use your system's regular browser (Chrome, Edge, etc.) instead of Puppeteer's bundled Chromium. This is useful for:
- Using your existing browser sessions and extensions
- Manually logging in to websites with your saved credentials
- Having a more natural browsing experience for multi-step workflows
- Testing with the same browser environment as your users
To enable default browser mode, set useDefaultBrowser: true
and visibleBrowser: true
in your tool parameters.
How Default Browser Mode Works
When you enable default browser mode:
- The tool will attempt to locate your system's default browser (Chrome, Edge, etc.)
- It launches your browser with remote debugging enabled on a random port
- Puppeteer connects to this browser instance instead of launching its own
- Your existing profiles, extensions, and cookies are available during the session
- The browser window remains visible so you can interact with it manually
This mode is particularly useful for workflows that require authentication or complex user interactions.
Browser Persistence
The MCP server can maintain a persistent browser session across multiple tool calls:
- When you use
login-and-wait
, the browser session is kept open - Subsequent calls to
screenshot-page
orscreenshot-element
withreuseAuthPage: true
will use the same page - This allows for multi-step workflows without having to re-authenticate
Cookie Management
Cookies are automatically saved for each domain you visit:
- After using
login-and-wait
, cookies are saved to the.mcp-screenshot-cookies
directory in your home folder - These cookies are automatically loaded when visiting the same domain again with
useSavedAuth: true
- You can clear cookies using the
clear-auth-cookies
tool
Example Workflow: Protected Page Screenshots
Here's an example workflow for taking screenshots of pages that require authentication:
- Manual Login Phase
This will open your default browser with the login page. You can manually log in, and once complete (either by detecting the success indicator or after navigating away from the login page), the session cookies will be saved.
- Take Screenshots Using Saved Session
This will take a screenshot of the account page using your saved authentication cookies in the same browser window.
- Take Screenshots of Specific Elements
- Clear Cookies When Done
This workflow allows you to interact with protected pages as if you were a regular user, completing the full authentication flow in your default browser.
Headless vs. Visible Mode
- Headless mode (
visibleBrowser: false
): Faster and more suitable for automated workflows where no user interaction is needed. - Visible mode (
visibleBrowser: true
): Shows the browser window, allowing for user interaction and manual verification. Required foruseDefaultBrowser: true
.
Platform Support
The default browser detection works on:
- macOS: Detects Chrome, Edge, and Safari
- Windows: Detects Chrome and Edge via registry or common installation paths
- Linux: Detects Chrome and Chromium via system commands
Troubleshooting
Common Issues
- Default browser not found: If the system can't find your default browser, it will fall back to Puppeteer's bundled Chromium.
- Connection issues: If there are problems connecting to the browser's debugging port, check if another instance is already using that port.
- Cookie issues: If authentication isn't working, try clearing cookies with the
clear-auth-cookies
tool.
Debugging
The MCP server logs helpful error messages to the console when issues occur. Check these messages for troubleshooting information.
This server cannot be installed
local-only server
The server can only run on the client's local machine because it depends on local resources.
Captures screenshots of web pages using Puppeteer, allowing AI agents to visually verify web applications and see their progress when generating web apps.
Related MCP Servers
- -securityFlicense-qualityEnables capturing screenshots of web pages and local HTML files through a simple MCP tool interface using Puppeteer with configurable options for dimensions and output paths.Last updated -104JavaScript
- AsecurityAlicenseAqualityEnables browser automation with Puppeteer, supporting navigation, form interactions, and connection to active Chrome instances for comprehensive web page interaction.Last updated -84708TypeScriptMIT License
- AsecurityAlicenseAqualityAn official MCP server implementation that allows AI assistants to capture website screenshots through the ScreenshotOne API, enabling visual context from web pages during conversations.Last updated -16TypeScriptMIT License
- -security-license-qualityAn MCP server that provides web development tools including taking screenshots of screens, enabling AI agents to capture and analyze visual content during development.Last updated -2TypeScript