Cloudflare Browser Rendering
/install cloudflare-browser-rendering-skill
Cloudflare Browser Rendering
Overview
Use this skill to bridge the gap between lightweight web_fetch and full interactive browser automation.
Routing rule:
- Use
web_fetchfor simple static pages and quick reads. - Use this skill when content depends on JavaScript rendering or when you need to crawl many related pages.
- Use
browserwhen the task requires interaction such as login, clicking, typing, or manual flow control.
Quick decision guide
- Single page, static, fastest path matters ->
web_fetch - Single page, JS-heavy, want clean markdown ->
/markdown - Whole docs/blog/help center crawl ->
/crawl - Needs login/UI actions ->
browser
If uncertain, start with web_fetch. Escalate to /markdown if the page is incomplete or empty. Escalate to /crawl only when multiple pages are needed.
Read references/decision-guide.md for routing details and references/*.md for endpoint notes.
Prerequisites
Expect these environment variables to be available before running the scripts:
CLOUDFLARE_API_TOKENCLOUDFLARE_ACCOUNT_ID
The token needs Browser Rendering Write for /markdown and crawl creation. Reading crawl results can use Browser Rendering Read or Write.
Single-page extraction with /markdown
Use scripts/cf_markdown.py.
Examples:
python3 scripts/cf_markdown.py --url https://example.com
python3 scripts/cf_markdown.py --url https://example.com --wait-until networkidle0
python3 scripts/cf_markdown.py --url https://example.com --wait-until networkidle0 --timeout-ms 60000
python3 scripts/cf_markdown.py --url https://example.com --cache-ttl 0 --json
python3 scripts/cf_markdown.py --html '\x3Cdiv>Hello\x3C/div>'
python3 scripts/cf_markdown.py --url https://example.com --user-agent 'Mozilla/5.0 ...'
python3 scripts/cf_markdown.py --url https://example.com --cookies-json '[{"name":"session","value":"abc","domain":"example.com"}]'
python3 scripts/cf_markdown.py --url https://example.com --authenticate-json '{"username":"u","password":"p"}'
python3 scripts/cf_markdown.py --url https://example.com --reject-request-pattern-json '["/^.*\\\\.(css)$/"]'
Guidelines:
- Prefer
--wait-until networkidle0ornetworkidle2for SPA/JS-heavy pages. - If a JS-heavy page times out, first raise
--timeout-ms(for example60000), then consider falling back todomcontentloadedif full idle waiting is too slow. - Use
--cache-ttl 0when freshness matters more than speed. - Use
--jsonwhen you want full API output for debugging. - Use raw JSON flags when you need advanced body fields without patching the script.
Multi-page crawling with /crawl
Use scripts/cf_crawl.py.
Examples:
python3 scripts/cf_crawl.py start --url https://developers.cloudflare.com/workers/ --depth 2 --limit 20 --format markdown
python3 scripts/cf_crawl.py wait --job-id \x3Cjob_id> --poll-seconds 5
python3 scripts/cf_crawl.py results --job-id \x3Cjob_id> --limit 20 --status completed
python3 scripts/cf_crawl.py run --url https://developers.cloudflare.com/workers/ --depth 2 --limit 20 --format markdown --wait
python3 scripts/cf_crawl.py run --url https://developers.cloudflare.com/workers/ --depth 2 --limit 20 --format markdown --wait --fetch-results --results-status completed --out-json out/crawl.json --out-markdown out/crawl.md
python3 scripts/cf_crawl.py start --url https://example.com --source links --goto-options-json '{"timeout":30000}'
Guidelines:
- Keep initial crawls small: low
depthand modestlimit. - Use
run --waitfor one-shot jobs. - Use
run --wait --fetch-resultswhen you want a full one-command workflow. - Use
start+wait+resultswhen you want more control. - Poll lightly; do not tight-loop.
- Prefer markdown format for downstream summarization or embeddings.
- Use
--out-jsonand--out-markdownfor large outputs instead of dumping everything into chat.
Output handling
For large crawls:
- First inspect summary fields: job status, total, finished, browser seconds used.
- Then fetch filtered results, usually
status=completed. - Avoid dumping huge markdown blobs into chat; summarize and point to saved output if needed.
Failure and fallback rules
- If
/markdownreturns incomplete content, retry with--wait-until networkidle0. - If
/crawlis overkill for the task, fall back to/markdownon key URLs. - If the site requires interaction or login, stop using this skill and switch to
browser. - If the API is unavailable or credentials are missing, report that clearly and fall back to
web_fetchwhen possible.
Resources
scripts/cf_markdown.py- rendered single-page Markdown extractionscripts/cf_crawl.py- async crawl job helperreferences/decision-guide.md- routing and fallback guidancereferences/markdown-endpoint.md- focused notes on/markdownreferences/crawl-endpoint.md- focused notes on/crawl
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install cloudflare-browser-rendering-skill - 安装完成后,直接呼叫该 Skill 的名称或使用
/cloudflare-browser-rendering-skill触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
Cloudflare Browser Rendering 是什么?
Use Cloudflare Browser Rendering REST APIs to extract rendered webpage content as Markdown or crawl whole sites asynchronously. Use when normal web_fetch is... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 344 次。
如何安装 Cloudflare Browser Rendering?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install cloudflare-browser-rendering-skill」即可一键安装,无需额外配置。
Cloudflare Browser Rendering 是免费的吗?
是的,Cloudflare Browser Rendering 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
Cloudflare Browser Rendering 支持哪些平台?
Cloudflare Browser Rendering 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 Cloudflare Browser Rendering?
由 Yangtao Chen(@cytwyatt)开发并维护,当前版本 v0.1.1。