chrome-cdp-skill
/install chrome-cdp-skill
Chrome CDP
Lightweight Chrome DevTools Protocol CLI. Connects directly via WebSocket, does not need Puppeteer, and works well with large tab counts.
Prerequisites
- Chrome (or Chromium, Brave, Edge, Vivaldi) with remote debugging enabled: open
chrome://inspect/#remote-debuggingand toggle the switch - Node.js 22+ (uses built-in WebSocket)
- No Python or pip packages are required
- No
npm installstep is required - If your browser's
DevToolsActivePortis in a non-standard location, setCDP_PORT_FILEto its full path
Quick setup
- Open Chrome and keep it running.
- Open
chrome://inspect/#remote-debugging. - Turn on remote debugging.
- Keep the browser open while using this skill.
- Run
{baseDir}/scripts/cdp.mjs listto confirm that tabs are visible.
On first access to a tab, Chrome may ask the user to approve debugging access.
Installation
- Recommended:
clawhub install chrome-cdp-skill - Manual: place this skill directory in your OpenClaw workspace
skills/folder - This skill does not require
npm install, Python, or pip packages
Safety
This skill can inspect and control a real local browser session. Commands such as eval, evalraw, click, type, and nav are intentionally powerful and may trigger warnings from security scanners.
Only use this skill when the user explicitly wants you to inspect or operate pages they already have open. Assume those tabs may contain sensitive logged-in content.
The skill only works after the user enables Chrome remote debugging. On first access to a tab, Chrome may ask the user to approve debugging access.
Commands
All commands use {baseDir}/scripts/cdp.mjs. The \x3Ctarget> is a unique targetId prefix from list; copy the full prefix shown in the list output (for example 6BE827FA). The CLI rejects ambiguous prefixes.
List open pages
{baseDir}/scripts/cdp.mjs list
Take a screenshot
{baseDir}/scripts/cdp.mjs shot \x3Ctarget> [file] # default: screenshot-\x3Ctarget>.png in runtime dir
Captures the viewport only. Scroll first with eval if you need content below the fold. Output includes the page's DPR and coordinate conversion hint (see Coordinates below).
Accessibility tree snapshot
{baseDir}/scripts/cdp.mjs snap \x3Ctarget>
Evaluate JavaScript
{baseDir}/scripts/cdp.mjs eval \x3Ctarget> \x3Cexpr>
Watch out: avoid index-based selection (
querySelectorAll(...)[i]) across multipleevalcalls when the DOM can change between them (e.g. after clicking Ignore, card indices shift). Collect all data in oneevalor use stable selectors.
Other commands
{baseDir}/scripts/cdp.mjs html \x3Ctarget> [selector] # full page or element HTML
{baseDir}/scripts/cdp.mjs nav \x3Ctarget> \x3Curl> # navigate and wait for load
{baseDir}/scripts/cdp.mjs net \x3Ctarget> # resource timing entries
{baseDir}/scripts/cdp.mjs click \x3Ctarget> \x3Cselector> # click element by CSS selector
{baseDir}/scripts/cdp.mjs clickxy \x3Ctarget> \x3Cx> \x3Cy> # click at CSS pixel coords
{baseDir}/scripts/cdp.mjs type \x3Ctarget> \x3Ctext> # Input.insertText at current focus; works in cross-origin iframes unlike eval
{baseDir}/scripts/cdp.mjs loadall \x3Ctarget> \x3Cselector> [ms] # click "load more" until gone (default 1500ms between clicks)
{baseDir}/scripts/cdp.mjs evalraw \x3Ctarget> \x3Cmethod> [json] # raw CDP command passthrough
{baseDir}/scripts/cdp.mjs open [url] # open new tab (each triggers Allow prompt)
{baseDir}/scripts/cdp.mjs stop [target] # stop daemon(s)
Coordinates
shot saves an image at native resolution: image pixels = CSS pixels × DPR. CDP Input events (clickxy etc.) take CSS pixels.
CSS px = screenshot image px / DPR
shot prints the DPR for the current page. Typical Retina (DPR=2): divide screenshot coords by 2.
Tips
- Prefer
snap --compactoverhtmlfor page structure. - Use
type(not eval) to enter text in cross-origin iframes —click/clickxyto focus first, thentype. - Chrome shows an "Allow debugging" modal once per tab on first access. A background daemon keeps the session alive so subsequent commands need no further approval. Daemons auto-exit after 20 minutes of inactivity.
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install chrome-cdp-skill - 安装完成后,直接呼叫该 Skill 的名称或使用
/chrome-cdp-skill触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
chrome-cdp-skill 是什么?
Interact with a local Chrome-family browser session over CDP when the user explicitly asks to inspect, debug, or interact with a page they already have open. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 478 次。
如何安装 chrome-cdp-skill?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install chrome-cdp-skill」即可一键安装,无需额外配置。
chrome-cdp-skill 是免费的吗?
是的,chrome-cdp-skill 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
chrome-cdp-skill 支持哪些平台?
chrome-cdp-skill 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(darwin, linux, win32)。
谁开发了 chrome-cdp-skill?
由 Web3ToolsHub(@web3toolshub)开发并维护,当前版本 v1.0.6。