Playwright MCP
Реальный headless-браузер (Chromium, Firefox, WebKit) от Microsoft. Открывает страницы с JS-рендерингом, кликает, заполняет формы, делает скриншоты. Работает через accessibility-tree — Claude получает структурированное представление страницы вместо сырого HTML. Незаменим, когда нужно прочитать SPA или сайт, который полностью отрисовывается JS. Простой fetch-MCP в таких случаях возвращает только заголовок, Playwright достаёт полный текст после рендера.
claude mcp add playwright -- npx -y @playwright/mcp@latest
Playwright MCP
A Model Context Protocol (MCP) server that provides browser automation capabilities using Playwright. This server enables LLMs to interact with web pages through structured accessibility snapshots, bypassing the need for screenshots or visually-tuned models.
Playwright MCP vs Playwright CLI
This package provides MCP interface into Playwright. If you are using a coding agent, you might benefit from using the CLI+SKILLS instead.
CLI: Modern coding agents increasingly favor CLI–based workflows exposed as SKILLs over MCP because CLI invocations are more token-efficient: they avoid loading large tool schemas and verbose accessibility trees into the model context, allowing agents to act through concise, purpose-built commands. This makes CLI + SKILLs better suited for high-throughput coding agents that must balance browser automation with large codebases, tests, and reasoning within limited context windows.
Learn more about Playwright CLI with SKILLS.MCP: MCP remains relevant for specialized agentic loops that benefit from persistent state, rich introspection, and iterative reasoning over page structure, such as exploratory automation, self-healing tests, or long-running autonomous workflows where maintaining continuous browser context outweighs token cost concerns.
Key Features
- Fast and lightweight. Uses Playwright's accessibility tree, not pixel-based input.
- LLM-friendly. No vision models needed, operates purely on structured data.
- Deterministic tool application. Avoids ambiguity common with screenshot-based approaches.
Requirements
- Node.js 18 or newer
- VS Code, Cursor, Windsurf, Claude Desktop, Goose, Junie or any other MCP client
Getting started
First, install the Playwright MCP server with your client.
Standard config works in most of the tools:
{
"mcpServers": {
"playwright": {
"command": "npx",
"args": [
"@playwright/mcp@latest"
]
}
}
}
Amp
Add via the Amp VS Code extension settings screen or by updating your settings.json file: ```json "amp.mcpServers": { "playwright": { "command": "npx", "args": [ "@playwright/mcp@latest" ] } } ``` **Amp CLI Setup:** Add via the `amp mcp add`command below ```bash amp mcp add playwright -- npx @playwright/mcp@latest ```Antigravity
Add via the Antigravity settings or by updating your configuration file: ```json { "mcpServers": { "playwright": { "command": "npx", "args": [ "@playwright/mcp@latest" ] } } } ```Claude Code
Use the Claude Code CLI to add the Playwright MCP server: ```bash claude mcp add playwright npx @playwright/mcp@latest ```Claude Desktop
Follow the MCP install [guide](https://modelcontextprotocol.io/quickstart/user), use the standard config above.Cline
Follow the instruction in the section [Configuring MCP Servers](https://docs.cline.bot/mcp/configuring-mcp-servers) **Example: Local Setup** Add the following to your [`cline_mcp_settings.json`](https://docs.cline.bot/mcp/configuring-mcp-servers#editing-mcp-settings-files) file: ```json { "mcpServers": { "playwright": { "type": "stdio", "command": "npx", "timeout": 30, "args": [ "-y", "@playwright/mcp@latest" ], "disabled": false } } } ```Codex
Use the Codex CLI to add the Playwright MCP server: ```bash codex mcp add playwright npx "@playwright/mcp@latest" ``` Alternatively, create or edit the configuration file `~/.codex/config.toml` and add: ```toml [mcp_servers.playwright] command = "npx" args = ["@playwright/mcp@latest"] ``` For more information, see the [Codex MCP documentation](https://github.com/openai/codex/blob/main/codex-rs/config.md#mcp_servers).Copilot
Use the Copilot CLI to interactively add the Playwright MCP server: ```bash /mcp add ``` Alternatively, create or edit the configuration file `~/.copilot/mcp-config.json` and add: ```json { "mcpServers": { "playwright": { "type": "local", "command": "npx", "tools": [ "*" ], "args": [ "@playwright/mcp@latest" ] } } } ``` For more information, see the [Copilot CLI documentation](https://docs.github.com/en/copilot/concepts/agents/about-copilot-cli).Cursor
#### Click the button to install: [Factory
Use the Factory CLI to add the Playwright MCP server: ```bash droid mcp add playwright "npx @playwright/mcp@latest" ``` Alternatively, type `/mcp` within Factory droid to open an interactive UI for managing MCP servers. For more information, see the [Factory MCP documentation](https://docs.factory.ai/cli/configuration/mcp).Gemini CLI
Follow the MCP install [guide](https://github.com/google-gemini/gemini-cli/blob/main/docs/tools/mcp-server.md#configure-the-mcp-server-in-settingsjson), use the standard config above.Goose
#### Click the button to install: [](https://block.github.io/goose/extension?cmd=npx&arg=%40playwright%2Fmcp%40latest&id=playwright&name=Playwright&description=Interact%20with%20web%20pages%20through%20structured%20accessibility%20snapshots%20using%20Playwright) #### Or install manually: Go to `Advanced settings` -> `Extensions` -> `Add custom extension`. Name to your liking, use type `STDIO`, and set the `command` to `npx @playwright/mcp`. Click "Add Extension".Junie
To add the Playwright MCP server in Junie CLI: 1. Type `/mcp` 2. Press `Ctrl+A` to add a new MCP server 3. Select **Playwright** from the list Alternatively, add to `.junie/mcp/mcp.json`: ```json { "mcpServers": { "Playwright": { "command": "npx", "args": [ "-y", "@playwright/mcp@latest" ] } } } ``` For more information, see the [Junie MCP configuration documentation](https://junie.jetbrains.com/docs/junie-cli-mcp-configuration.html).Kiro
[](https://kiro.dev/launch/mcp/add?name=playwright&config=%7B%22command%22%3A%22npx%22%2C%22args%22%3A%5B%22%40playwright%2Fmcp%40latest%22%5D%7D) Follow the MCP Servers [documentation](https://kiro.dev/docs/mcp/). For example in `.kiro/settings/mcp.json`: ```json { "mcpServers": { "playwright": { "command": "npx", "args": [ "@playwright/mcp@latest" ] } } } ```LM Studio
#### Click the button to install: [](https://lmstudio.ai/install-mcp?name=playwright&config=eyJjb21tYW5kIjoibnB4IiwiYXJncyI6WyJAcGxheXdyaWdodC9tY3BAbGF0ZXN0Il19) #### Or install manually: Go to `Program` in the right sidebar -> `Install` -> `Edit mcp.json`. Use the standard config above.opencode
Follow the MCP Servers [documentation](https://opencode.ai/docs/mcp-servers/). For example in `~/.config/opencode/opencode.json`: ```json { "$schema": "https://opencode.ai/config.json", "mcp": { "playwright": { "type": "local", "command": [ "npx", "@playwright/mcp@latest" ], "enabled": true } } } ```Qodo Gen
Open [Qodo Gen](https://docs.qodo.ai/qodo-documentation/qodo-gen) chat panel in VSCode or IntelliJ → Connect more tools → + Add new MCP → Paste the standard config above. ClickSave.
VS Code
#### Click the button to install: [Warp
Go to `Settings` -> `AI` -> `Manage MCP Servers` -> `+ Add` to [add an MCP Server](https://docs.warp.dev/knowledge-and-collaboration/mcp#adding-an-mcp-server). Use the standard config above. Alternatively, use the slash command `/add-mcp` in the Warp prompt and paste the standard config from above: ```js { "mcpServers": { "playwright": { "command": "npx", "args": [ "@playwright/mcp@latest" ] } } } ```Windsurf
Follow Windsurf MCP [documentation](https://docs.windsurf.com/windsurf/cascade/mcp). Use the standard config above.Configuration
Playwright MCP server supports following arguments. They can be provided in the JSON configuration above, as a part of the "args" list:
| Option | Description |
|---|---|
| --allowed-hosts | comma-separated list of hosts this server is allowed to serve from. Defaults to the host the server is bound to. Pass '' to disable the host check. *env PLAYWRIGHT_MCP_ALLOWED_HOSTS
|
| --allowed-origins | semicolon-separated list of TRUSTED origins to allow the browser to request. Default is to allow all. Important: does not serve as a security boundary and does not affect redirects. env PLAYWRIGHT_MCP_ALLOWED_ORIGINS
|
| --allow-unrestricted-file-access | allow access to files outside of the workspace roots. Also allows unrestricted access to file:// URLs. By default access to file system is restricted to workspace root directories (or cwd if no roots are configured) only, and navigation to file:// URLs is blocked. env PLAYWRIGHT_MCP_ALLOW_UNRESTRICTED_FILE_ACCESS
|
| --blocked-origins | semicolon-separated list of origins to block the browser from requesting. Blocklist is evaluated before allowlist. If used without the allowlist, requests not matching the blocklist are still allowed. Important: does not serve as a security boundary and does not affect redirects. env PLAYWRIGHT_MCP_BLOCKED_ORIGINS
|
| --block-service-workers | block service workers env PLAYWRIGHT_MCP_BLOCK_SERVICE_WORKERS
|
| --browser | browser or chrome channel to use, possible values: chrome, firefox, webkit, msedge. env PLAYWRIGHT_MCP_BROWSER
|
| --caps | comma-separated list of additional capabilities to enable, possible values: vision, pdf, devtools. env PLAYWRIGHT_MCP_CAPS
|
| --cdp-endpoint | CDP endpoint to connect to. env PLAYWRIGHT_MCP_CDP_ENDPOINT
|
| --cdp-header | CDP headers to send with the connect request, multiple can be specified. env PLAYWRIGHT_MCP_CDP_HEADER
|
| --cdp-timeout | timeout in milliseconds for connecting to CDP endpoint, defaults to 30000ms env PLAYWRIGHT_MCP_CDP_TIMEOUT
|
| --codegen | specify the language to use for code generation, possible values: "typescript", "none". Default is "typescript". env PLAYWRIGHT_MCP_CODEGEN
|
| --config | path to the configuration file. env PLAYWRIGHT_MCP_CONFIG
|
| --console-level | level of console messages to return: "error", "warning", "info", "debug". Each level includes the messages of more severe levels. env PLAYWRIGHT_MCP_CONSOLE_LEVEL
|
| --device | device to emulate, for example: "iPhone 15" env PLAYWRIGHT_MCP_DEVICE
|
| --executable-path | path to the browser executable. env PLAYWRIGHT_MCP_EXECUTABLE_PATH
|
| --extension | Connect to a running browser instance (Edge/Chrome only). Requires the "Playwright Extension" to be installed. env PLAYWRIGHT_MCP_EXTENSION
|
| --endpoint | Bound browser endpoint to connect to. env PLAYWRIGHT_MCP_ENDPOINT
|
| --grant-permissions | List of permissions to grant to the browser context, for example "geolocation", "clipboard-read", "clipboard-write". env PLAYWRIGHT_MCP_GRANT_PERMISSIONS
|
| --headless | run browser in headless mode, headed by default env PLAYWRIGHT_MCP_HEADLESS
|
| --host | host to bind server to. Default is localhost. Use 0.0.0.0 to bind to all interfaces. env PLAYWRIGHT_MCP_HOST
|
| --ignore-https-errors | ignore https errors env PLAYWRIGHT_MCP_IGNORE_HTTPS_ERRORS
|
| --init-page | path to TypeScript file to evaluate on Playwright page object env PLAYWRIGHT_MCP_INIT_PAGE
|
| --init-script | path to JavaScript file to add as an initialization script. The script will be evaluated in every page before any of the page's scripts. Can be specified multiple times. env PLAYWRIGHT_MCP_INIT_SCRIPT
|
| --isolated | keep the browser profile in memory, do not save it to disk. env PLAYWRIGHT_MCP_ISOLATED
|
| --image-responses | whether to send image responses to the client. Can be "allow" or "omit", Defaults to "allow". env PLAYWRIGHT_MCP_IMAGE_RESPONSES
|
| --no-sandbox | disable the sandbox for all process types that are normally sandboxed. env PLAYWRIGHT_MCP_NO_SANDBOX
|
| --output-dir | path to the directory for output files. env PLAYWRIGHT_MCP_OUTPUT_DIR
|
| --output-mode | whether to save snapshots, console messages, network logs to a file or to the standard output. Can be "file" or "stdout". Default is "stdout". env PLAYWRIGHT_MCP_OUTPUT_MODE
|
| --port | port to listen on for SSE transport. env PLAYWRIGHT_MCP_PORT
|
| --proxy-bypass | comma-separated domains to bypass proxy, for example ".com,chromium.org,.domain.com" env PLAYWRIGHT_MCP_PROXY_BYPASS
|
| --proxy-server | specify proxy server, for example "http://myproxy:3128" or "socks5://myproxy:8080" env PLAYWRIGHT_MCP_PROXY_SERVER
|
| --sandbox | enable the sandbox for all process types that are normally not sandboxed. env PLAYWRIGHT_MCP_SANDBOX
|
| --save-session | Whether to save the Playwright MCP session into the output directory. env PLAYWRIGHT_MCP_SAVE_SESSION
|
| --secrets | path to a file containing secrets in the dotenv format env PLAYWRIGHT_MCP_SECRETS
|
| --shared-browser-context | reuse the same browser context between all connected HTTP clients. env PLAYWRIGHT_MCP_SHARED_BROWSER_CONTEXT
|
| --snapshot-mode | when taking snapshots for responses, specifies the mode to use. Can be "full" or "none". Default is "full". env PLAYWRIGHT_MCP_SNAPSHOT_MODE
|
| --storage-state | path to the storage state file for isolated sessions. env PLAYWRIGHT_MCP_STORAGE_STATE
|
| --test-id-attribute | specify the attribute to use for test ids, defaults to "data-testid" env PLAYWRIGHT_MCP_TEST_ID_ATTRIBUTE
|
| --timeout-action | specify action timeout in milliseconds, defaults to 5000ms env PLAYWRIGHT_MCP_TIMEOUT_ACTION
|
| --timeout-navigation | specify navigation timeout in milliseconds, defaults to 60000ms env PLAYWRIGHT_MCP_TIMEOUT_NAVIGATION
|
| --user-agent | specify user agent string env PLAYWRIGHT_MCP_USER_AGENT
|
| --user-data-dir | path to the user data directory. If not specified, a temporary directory will be created. env PLAYWRIGHT_MCP_USER_DATA_DIR
|
| --viewport-size | specify browser viewport size in pixels, for example "1280x720" env PLAYWRIGHT_MCP_VIEWPORT_SIZE
|
User profile
You can run Playwright MCP with persistent profile like a regular browser (default), in isolated contexts for testing sessions, or connect to your existing browser using the browser extension.
Persistent profile
All the logged in information will be stored in the persistent profile, you can delete it between sessions if you'd like to clear the offline state.
Persistent profile is located at the following locations and you can override it with the --user-data-dir argument.
# Windows
%USERPROFILE%\AppData\Local\ms-playwright\mcp-{channel}-{workspace-hash}
# macOS
- ~/Library/Caches/ms-playwright/mcp-{channel}-{workspace-hash}
# Linux
- ~/.cache/ms-playwright/mcp-{channel}-{workspace-hash}
{workspace-hash} is derived from the MCP client's workspace root, so different projects get separate profiles automatically.
Isolated
In the isolated mode, each session is started in the isolated profile. Every time you ask MCP to close the browser,
the session is closed and all the storage state for this session is lost. You can provide initial storage state
to the browser via the config's contextOptions or via the --storage-state argument. Learn more about the storage
state here.
{
"mcpServers": {
"playwright": {
"command": "npx",
"args": [
"@playwright/mcp@latest",
"--isolated",
"--storage-state={path/to/storage.json}"
]
}
}
}
Browser Extension
The Playwright MCP Chrome Extension allows you to connect to existing browser tabs and leverage your logged-in sessions and browser state. See microsoft/playwright › packages/extension for installation and setup instructions.
Initial state
There are multiple ways to provide the initial state to the browser context or a page.
For the storage state, you can either:
- Start with a user data directory using the --user-data-dir argument. This will persist all browser data between the sessions.
- Start with a storage state file using the --storage-state argument. This will load cookies and local storage from the file into an isolated browser context.
For the page state, you can use:
-
--init-pageto point to a TypeScript file that will be evaluated on the Playwright page object. This allows you to run arbitrary code to set up the page.
// init-page.ts
export default async ({ page }) => {
await page.context().grantPermissions(['geolocation']);
await page.context().setGeolocation({ latitude: 37.7749, longitude: -122.4194 });
await page.setViewportSize({ width: 1280, height: 720 });
};
-
--init-scriptto point to a JavaScript file that will be added as an initialization script. The script will be evaluated in every page before any of the page's scripts. This is useful for overriding browser APIs or setting up the environment.
// init-script.js
window.isPlaywrightMCP = true;
Configuration file
The Playwright MCP server can be configured using a JSON configuration file. You can specify the configuration file
using the --config command line option:
npx @playwright/mcp@latest --config path/to/config.json
Configuration file schema
```typescript { /** * The browser to use. */ browser?: { /** * The type of browser to use. */ browserName?: 'chromium' | 'firefox' | 'webkit'; /** * Keep the browser profile in memory, do not save it to disk. */ isolated?: boolean; /** * Path to a user data directory for browser profile persistence. * Temporary directory is created by default. */ userDataDir?: string; /** * Launch options passed to * @see https://playwright.dev/docs/api/class-browsertype#browser-type-launch-persistent-context * * This is useful for settings options like `channel`, `headless`, `executablePath`, etc. */ launchOptions?: playwright.LaunchOptions; /** * Context options for the browser context. * * This is useful for settings options like `viewport`. */ contextOptions?: playwright.BrowserContextOptions; /** * Chrome DevTools Protocol endpoint to connect to an existing browser instance in case of Chromium family browsers. */ cdpEndpoint?: string; /** * CDP headers to send with the connect request. */ cdpHeaders?: Record; /** * Timeout in milliseconds for connecting to CDP endpoint. Defaults to 30000 (30 seconds). Pass 0 to disable timeout. */ cdpTimeout?: number; /** * Remote endpoint to connect to an existing Playwright server. */ remoteEndpoint?: string; /** * Paths to TypeScript files to add as initialization scripts for Playwright page. */ initPage?: string[]; /** * Paths to JavaScript files to add as initialization scripts. * The scripts will be evaluated in every page before any of the page's scripts. */ initScript?: string[]; }, /** * Connect to a running browser instance (Edge/Chrome only). If specified, `browser` * config is ignored. * Requires the "Playwright Extension" to be installed. */ extension?: boolean; server?: { /** * The port to listen on for SSE or MCP transport. */ port?: number; /** * The host to bind the server to. Default is localhost. Use 0.0.0.0 to bind to all interfaces. */ host?: string; /** * The hosts this server is allowed to serve from. Defaults to the host server is bound to. * This is not for CORS, but rather for the DNS rebinding protection. */ allowedHosts?: string[]; }, /** * List of enabled tool capabilities. Possible values: * - 'core': Core browser automation features. * - 'pdf': PDF generation and manipulation. * - 'vision': Coordinate-based interactions. * - 'devtools': Developer tools features. */ capabilities?: ToolCapability[]; /** * Whether to save the Playwright session into the output directory. */ saveSession?: boolean; /** * Reuse the same browser context between all connected HTTP clients. */ sharedBrowserContext?: boolean; /** * Secrets are used to replace matching plain text in the tool responses to prevent the LLM * from accidentally getting sensitive data. It is a convenience and not a security feature, * make sure to always examine information coming in and from the tool on the client. */ secrets?: Record; /** * The directory to save output files. */ outputDir?: string; console?: { /** * The level of console messages to return. Each level includes the messages of more severe levels. Defaults to "info". */ level?: 'error' | 'warning' | 'info' | 'debug'; }, network?: { /** * List of origins to allow the browser to request. Default is to allow all. Origins matching both `allowedOrigins` and `blockedOrigins` will be blocked. * * Supported formats: * - Full origin: `https://example.com:8080` - matches only that origin * - Wildcard port: `http://localhost:*` - matches any port on localhost with http protocol */ allowedOrigins?: string[]; /** * List of origins to block the browser to request. Origins matching both `allowedOrigins` and `blockedOrigins` will be blocked. * * Supported formats: * - Full origin: `https://example.com:8080` - matches only that origin * - Wildcard port: `http://localhost:*` - matches any port on localhost with http protocol */ blockedOrigins?: string[]; }; /** * Specify the attribute to use for test ids, defaults to "data-testid". */ testIdAttribute?: string; timeouts?: { /* * Configures default action timeout: https://playwright.dev/docs/api/class-page#page-set-default-timeout. Defaults to 5000ms. */ action?: number; /* * Configures default navigation timeout: https://playwright.dev/docs/api/class-page#page-set-default-navigation-timeout. Defaults to 60000ms. */ navigation?: number; /** * Configures default expect timeout: https://playwright.dev/docs/test-timeouts#expect-timeout. Defaults to 5000ms. */ expect?: number; }; /** * Whether to send image responses to the client. Can be "allow", "omit", or "auto". Defaults to "auto", which sends images if the client can display them. */ imageResponses?: 'allow' | 'omit'; snapshot?: { /** * When taking snapshots for responses, specifies the mode to use. */ mode?: 'full' | 'none'; }; /** * allowUnrestrictedFileAccess acts as a guardrail to prevent the LLM from accidentally * wandering outside its intended workspace. It is a convenience defense to catch unintended * file access, not a secure boundary; a deliberate attempt to reach other directories can be * easily worked around, so always rely on client-level permissions for true security. */ allowUnrestrictedFileAccess?: boolean; /** * Specify the language to use for code generation. */ codegen?: 'typescript' | 'none'; } ```Standalone MCP server
When running headed browser on system w/o display or from worker processes of the IDEs,
run the MCP server from environment with the DISPLAY and pass the --port flag to enable HTTP transport.
npx @playwright/mcp@latest --port 8931
And then in MCP client config, set the url to the HTTP endpoint:
{
"mcpServers": {
"playwright": {
"url": "http://localhost:8931/mcp"
}
}
}
Security
Playwright MCP is not a security boundary. See MCP Security Best Practices for guidance on securing your deployment.