Untuk penyiapan, konfigurasi, dan pemecahan masalah, lihat Browser. Halaman ini adalah referensi untuk API HTTP kontrol lokal, CLIDocumentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
openclaw browser,
dan pola skrip (snapshot, ref, tunggu, alur debug).
API Kontrol (opsional)
Hanya untuk integrasi lokal, Gateway mengekspos API HTTP loopback kecil:- Status/mulai/hentikan:
GET /,POST /start,POST /stop - Tab:
GET /tabs,POST /tabs/open,POST /tabs/focus,DELETE /tabs/:targetId - Snapshot/tangkapan layar:
GET /snapshot,POST /screenshot - Tindakan:
POST /navigate,POST /act - Hook:
POST /hooks/file-chooser,POST /hooks/dialog - Unduhan:
POST /download,POST /wait/download - Izin:
POST /permissions/grant - Debugging:
GET /console,POST /pdf - Debugging:
GET /errors,GET /requests,POST /trace/start,POST /trace/stop,POST /highlight - Jaringan:
POST /response/body - Status:
GET /cookies,POST /cookies/set,POST /cookies/clear - Status:
GET /storage/:kind,POST /storage/:kind/set,POST /storage/:kind/clear - Pengaturan:
POST /set/offline,POST /set/headers,POST /set/credentials,POST /set/geolocation,POST /set/media,POST /set/timezone,POST /set/locale,POST /set/device
?profile=<name>. POST /start?headless=true meminta
peluncuran headless sekali jalan untuk profil terkelola lokal tanpa mengubah
konfigurasi browser yang disimpan; profil attach-only, CDP jarak jauh, dan
existing-session menolak override itu karena OpenClaw tidak meluncurkan proses
browser tersebut.
Jika autentikasi gateway shared-secret dikonfigurasi, rute HTTP browser juga memerlukan autentikasi:
Authorization: Bearer <gateway token>x-openclaw-password: <gateway password>atau autentikasi HTTP Basic dengan kata sandi tersebut
- API browser loopback mandiri ini tidak menggunakan header identitas trusted-proxy atau Tailscale Serve.
- Jika
gateway.auth.modeadalahnoneatautrusted-proxy, rute browser loopback ini tidak mewarisi mode pembawa identitas tersebut; pertahankan agar hanya loopback.
Kontrak error /act
POST /act menggunakan respons error terstruktur untuk validasi tingkat rute dan
kegagalan kebijakan:
code saat ini:
ACT_KIND_REQUIRED(HTTP 400):kindhilang atau tidak dikenali.ACT_INVALID_REQUEST(HTTP 400): payload tindakan gagal dinormalisasi atau divalidasi.ACT_SELECTOR_UNSUPPORTED(HTTP 400):selectordigunakan dengan jenis tindakan yang tidak didukung.ACT_EVALUATE_DISABLED(HTTP 403):evaluate(atauwait --fn) dinonaktifkan oleh konfigurasi.ACT_TARGET_ID_MISMATCH(HTTP 403):targetIdtingkat atas atau batch bertentangan dengan target permintaan.ACT_EXISTING_SESSION_UNSUPPORTED(HTTP 501): tindakan tidak didukung untuk profil existing-session.
{ "error": "<message>" } tanpa kolom
code.
Persyaratan Playwright
Beberapa fitur (navigate/act/snapshot AI/snapshot peran, tangkapan layar elemen, PDF) memerlukan Playwright. Jika Playwright tidak terpasang, endpoint tersebut mengembalikan error 501 yang jelas. Yang tetap berfungsi tanpa Playwright:- Snapshot ARIA
- Snapshot aksesibilitas bergaya peran (
--interactive,--compact,--depth,--efficient) saat WebSocket CDP per tab tersedia. Ini adalah fallback untuk inspeksi dan penemuan ref; Playwright tetap menjadi mesin tindakan utama. - Tangkapan layar halaman untuk browser
openclawterkelola saat WebSocket CDP per tab tersedia - Tangkapan layar halaman untuk profil
existing-session/ Chrome MCP - Tangkapan layar berbasis ref
existing-session(--ref) dari output snapshot
navigateact- Snapshot AI yang bergantung pada format snapshot AI native Playwright
- Tangkapan layar elemen dengan selector CSS (
--element) - ekspor PDF browser penuh
--full-page; rute mengembalikan fullPage is not supported for element screenshots.
Jika Anda melihat Playwright is not available in this gateway build, Gateway paket
tidak memiliki dependensi runtime browser inti. Pasang ulang atau perbarui
OpenClaw, lalu mulai ulang gateway. Untuk Docker, pasang juga binary browser
Chromium seperti ditunjukkan di bawah.
Instalasi Docker Playwright
Jika Gateway Anda berjalan di Docker, hindarinpx playwright (konflik override npm).
Untuk image kustom, masukkan Chromium ke dalam image:
PLAYWRIGHT_BROWSERS_PATH (misalnya,
/home/node/.cache/ms-playwright) dan pastikan /home/node dipertahankan melalui
OPENCLAW_HOME_VOLUME atau bind mount. OpenClaw mendeteksi otomatis Chromium
yang dipertahankan di Linux. Lihat Docker.
Cara kerjanya (internal)
Server kontrol loopback kecil menerima permintaan HTTP dan terhubung ke browser berbasis Chromium melalui CDP. Tindakan lanjutan (klik/ketik/snapshot/PDF) melewati Playwright di atas CDP; saat Playwright tidak ada, hanya operasi non-Playwright yang tersedia. Agen melihat satu antarmuka stabil sementara browser dan profil lokal/jarak jauh dapat berganti bebas di bawahnya.Referensi cepat CLI
Semua perintah menerima--browser-profile <name> untuk menargetkan profil tertentu, dan --json untuk output yang dapat dibaca mesin.
Basics: status, tabs, open/focus/close
Basics: status, tabs, open/focus/close
Inspection: screenshot, snapshot, console, errors, requests
Inspection: screenshot, snapshot, console, errors, requests
Actions: navigate, click, type, drag, wait, evaluate
Actions: navigate, click, type, drag, wait, evaluate
State: cookies, storage, offline, headers, geo, device
State: cookies, storage, offline, headers, geo, device
uploaddandialogadalah panggilan arming; jalankan sebelum klik/tekan yang memicu pemilih/dialog.click/type/dll. memerlukanrefdarisnapshot(numerik12, ref perane12, atau ref ARIA yang dapat ditindaklanjutiax12). Selector CSS sengaja tidak didukung untuk tindakan. Gunakanclick-coordssaat posisi viewport yang terlihat adalah satu-satunya target yang andal.- Jalur unduhan, trace, dan unggahan dibatasi ke root sementara OpenClaw:
/tmp/openclaw{,/downloads,/uploads}(fallback:${os.tmpdir()}/openclaw/...). uploadjuga dapat menetapkan input file secara langsung melalui--input-refatau--element.
suggestedTargetId dari tabs dalam skrip.
Ringkasan flag snapshot:
--format ai(default dengan Playwright): snapshot AI dengan ref numerik (aria-ref="<n>").--format aria: pohon aksesibilitas dengan refaxN. Saat Playwright tersedia, OpenClaw mengikat ref dengan ID DOM backend ke halaman langsung agar tindakan lanjutan dapat menggunakannya; jika tidak, perlakukan output sebagai hanya untuk inspeksi.--efficient(atau--mode efficient): preset snapshot peran ringkas. Tetapkanbrowser.snapshotDefaults.mode: "efficient"untuk menjadikannya default (lihat Konfigurasi Gateway).--interactive,--compact,--depth,--selectormemaksa snapshot peran dengan refref=e12.--frame "<iframe>"membatasi snapshot peran ke iframe.--labelsmenambahkan tangkapan layar khusus viewport dengan label ref yang ditumpangkan (mencetakMEDIA:<path>).--urlsmenambahkan tujuan tautan yang ditemukan ke snapshot AI.
Snapshot dan ref
OpenClaw mendukung dua gaya “snapshot”:-
Snapshot AI (ref numerik):
openclaw browser snapshot(default;--format ai)- Output: snapshot teks yang menyertakan ref numerik.
- Tindakan:
openclaw browser click 12,openclaw browser type 23 "hello". - Secara internal, ref diselesaikan melalui
aria-refPlaywright.
-
Snapshot peran (ref peran seperti
e12):openclaw browser snapshot --interactive(atau--compact,--depth,--selector,--frame)- Output: daftar/pohon berbasis peran dengan
[ref=e12](dan opsional[nth=1]). - Tindakan:
openclaw browser click e12,openclaw browser highlight e12. - Secara internal, ref diselesaikan melalui
getByRole(...)(ditambahnth()untuk duplikat). - Tambahkan
--labelsuntuk menyertakan tangkapan layar viewport dengan labele12yang ditumpangkan. - Tambahkan
--urlssaat teks tautan ambigu dan agen memerlukan target navigasi konkret.
- Output: daftar/pohon berbasis peran dengan
-
Snapshot ARIA (ref ARIA seperti
ax12):openclaw browser snapshot --format aria- Output: pohon aksesibilitas sebagai node terstruktur.
- Tindakan:
openclaw browser click ax12berfungsi saat path snapshot dapat mengikat ref melalui Playwright dan id DOM backend Chrome.
-
Jika Playwright tidak tersedia, snapshot ARIA masih dapat berguna untuk
inspeksi, tetapi ref mungkin tidak dapat ditindaklanjuti. Ambil snapshot ulang dengan
--format aiatau--interactivesaat Anda membutuhkan ref tindakan. -
Bukti Docker untuk path fallback raw-CDP:
pnpm test:docker:browser-cdp-snapshotmemulai Chromium dengan CDP, menjalankanbrowser doctor --deep, dan memverifikasi snapshot role menyertakan URL tautan, elemen yang dapat diklik yang dipromosikan kursor, dan metadata iframe.
- Ref tidak stabil antar navigasi; jika sesuatu gagal, jalankan ulang
snapshotdan gunakan ref baru. /actmengembalikantargetIdraw saat ini setelah penggantian yang dipicu tindakan ketika dapat membuktikan tab pengganti. Tetap gunakan id/label tab yang stabil untuk perintah lanjutan.- Jika snapshot role diambil dengan
--frame, ref role dicakup ke iframe tersebut hingga snapshot role berikutnya. - Ref
axNyang tidak dikenal atau sudah usang gagal cepat alih-alih jatuh ke selectoraria-refPlaywright. Jalankan snapshot baru pada tab yang sama saat hal itu terjadi.
Peningkatan kemampuan wait
Anda dapat menunggu lebih dari sekadar waktu/teks:- Tunggu URL (glob didukung oleh Playwright):
openclaw browser wait --url "**/dash"
- Tunggu status pemuatan:
openclaw browser wait --load networkidle
- Tunggu predicate JS:
openclaw browser wait --fn "window.ready===true"
- Tunggu selector menjadi terlihat:
openclaw browser wait "#main"
Alur kerja debug
Saat tindakan gagal (mis. “not visible”, “strict mode violation”, “covered”):openclaw browser snapshot --interactive- Gunakan
click <ref>/type <ref>(utamakan ref role dalam mode interaktif) - Jika masih gagal:
openclaw browser highlight <ref>untuk melihat apa yang ditargetkan Playwright - Jika halaman berperilaku aneh:
openclaw browser errors --clearopenclaw browser requests --filter api --clear
- Untuk debugging mendalam: rekam trace:
openclaw browser trace start- reproduksi masalahnya
openclaw browser trace stop(mencetakTRACE:<path>)
Output JSON
--json digunakan untuk scripting dan tooling terstruktur.
Contoh:
refs plus blok stats kecil (lines/chars/refs/interactive) sehingga tool dapat menalar ukuran dan kepadatan payload.
Pengaturan status dan lingkungan
Ini berguna untuk alur kerja “buat situs berperilaku seperti X”:- Cookie:
cookies,cookies set,cookies clear - Storage:
storage local|session get|set|clear - Offline:
set offline on|off - Header:
set headers --headers-json '{"X-Debug":"1"}'(legacyset headers --json '{"X-Debug":"1"}'tetap didukung) - HTTP basic auth:
set credentials user pass(atau--clear) - Geolokasi:
set geo <lat> <lon> --origin "https://example.com"(atau--clear) - Media:
set media dark|light|no-preference|none - Zona waktu / locale:
set timezone ...,set locale ... - Perangkat / viewport:
set device "iPhone 14"(preset perangkat Playwright)set viewport 1280 720
Keamanan dan privasi
- Profil browser openclaw dapat berisi sesi yang sudah login; perlakukan sebagai sensitif.
browser act kind=evaluate/openclaw browser evaluatedanwait --fnmenjalankan JavaScript arbitrer dalam konteks halaman. Prompt injection dapat mengarahkan ini. Nonaktifkan denganbrowser.evaluateEnabled=falsejika Anda tidak membutuhkannya.- Untuk login dan catatan anti-bot (X/Twitter, dll.), lihat Login browser + posting X/Twitter.
- Jaga host Gateway/node tetap privat (loopback atau hanya tailnet).
- Endpoint CDP jarak jauh sangat kuat; tunnel dan lindungi endpoint tersebut.
Terkait
- Browser - ikhtisar, konfigurasi, profil, keamanan
- Login browser - masuk ke situs
- Pemecahan masalah Browser Linux
- Pemecahan masalah Browser WSL2