Navigateur (géré par OpenClaw)
OpenClaw peut exécuter un profil Chrome/Brave/Edge/Chromium dédié que l’agent contrôle. Il est isolé de votre navigateur personnel et est géré par un petit service de contrôle local à l’intérieur de la Gateway (en boucle uniquement).
Vue du débutant :
- Considérez-le comme un navigateur distinct, réservé à l’agent.
- Le profil
openclawne touche pas à votre profil de navigateur personnel. - L’agent peut ouvrir des onglets, lire des pages, cliquer et taper dans une voie sécurisée.
- Le profil intégré
users’attache à votre vraie session Chrome connectée via Chrome MCP.
Ce que vous obtenez
Section intitulée « Ce que vous obtenez »- Un profil de navigateur distinct nommé openclaw (accent orange par défaut).
- Contrôle déterministe des onglets (liste/ouverture/focus/fermeture).
- Actions de l’agent (clic/frappé/glissement/sélection), instantanés, captures d’écran, PDF.
- Une compétence
browser-automationgroupée qui enseigne aux agents la boucle de récupération par instantané, onglet stable, référence obsolète et bloqueur manuel lorsque le plugin de navigateur est activé. - Support multiprofil en option (
openclaw,work,remote, …).
Ce navigateur n’est pas votre navigateur quotidien. C’est une surface sûre et isolée pour l’automatisation et la vérification par l’agent.
Démarrage rapide
Section intitulée « Démarrage rapide »openclaw browser --browser-profile openclaw doctoropenclaw browser --browser-profile openclaw doctor --deepopenclaw browser --browser-profile openclaw statusopenclaw browser --browser-profile openclaw startopenclaw browser --browser-profile openclaw open https://example.comopenclaw browser --browser-profile openclaw snapshotSi vous obtenez “Browser disabled”, activez-le dans la configuration (voir ci-dessous) et redémarrez le Gateway.
Si openclaw browser est entièrement manquant, ou si l’agent indique que l’outil de navigation n’est pas disponible, passez à Commande ou outil de navigateur manquant.
Contrôle des plugins
Section intitulée « Contrôle des plugins »L’outil browser par défaut est un plugin groupé. Désactivez-le pour le remplacer par un autre plugin qui enregistre le même nom d’outil browser :
{ plugins: { entries: { browser: { enabled: false, }, }, },}Les valeurs par défaut nécessitent à la fois plugins.entries.browser.enabled et browser.enabled=true. Désactiver uniquement le plugin supprime la CLI openclaw browser, la méthode de passerelle browser.request, l’outil de l’agent et le service de contrôle en une seule unité ; votre configuration browser.* reste intacte pour un remplacement.
Les modifications de la configuration du navigateur nécessitent un redémarrage de la Gateway afin que le plugin puisse réenregistrer son service.
Conseils à l’agent
Section intitulée « Conseils à l’agent »Remarque sur le profil d’outil : tools.profile: "coding" inclut web_search et
web_fetch, mais n’inclut pas l’outil complet browser. Si l’agent ou un
sous-agent généré doit utiliser l’automatisation du navigateur, ajoutez le navigateur au niveau
du profil :
{ tools: { profile: "coding", alsoAllow: ["browser"], },}Pour un agent unique, utilisez agents.list[].tools.alsoAllow: ["browser"].
tools.subagents.tools.allow: ["browser"] seul ne suffit pas car la stratégie de sous-agent
est appliquée après le filtrage par profil.
Le plugin navigateur fournit deux niveaux de guidage pour l’agent :
- La description de l’outil
browsercontient le contrat toujours actif compact : choisir le bon profil, garder les références sur le même onglet, utilisertabId/labels pour le ciblage d’onglet, et charger la compétence navigateur pour les tâches en plusieurs étapes. - La compétence
browser-automationintégrée contient la boucle de fonctionnement plus longue : vérifier d’abord le statut/les onglets, étiqueter les onglets de tâche, prendre une capture d’écran avant d’agir, prendre une nouvelle capture après les changements d’interface, récupérer les références obsolètes une fois, et signaler les bloqueurs de connexion/2FA/captcha ou de caméra/microphone comme une action manuelle au lieu de deviner.
Les compétences intégrées au plugin sont répertoriées dans les compétences disponibles de l’agent lorsque le plugin est activé. Les instructions complètes de la compétence sont chargées à la demande, de sorte que les tours de routine ne paient pas le coût complet en tokens.
Commande ou outil navigateur manquant
Section intitulée « Commande ou outil navigateur manquant »Si openclaw browser est inconnu après une mise à niveau, browser.request est manquant, ou si l’agent signale que l’outil navigateur n’est pas disponible, la cause habituelle est une liste plugins.allow qui omet browser et qu’aucun bloc de configuration racine browser n’existe. Ajoutez-le :
{ plugins: { allow: ["telegram", "browser"], },}Un bloc racine browser explicite, par exemple browser.enabled=true ou browser.profiles.<name>, active le plugin navigateur intégré même sous un plugins.allow restrictif, correspondant au comportement de configuration du canal. plugins.entries.browser.enabled=true et tools.alsoAllow: ["browser"] ne remplacent pas l’appartenance à la liste verte par eux-mêmes. Supprimer entièrement plugins.allow rétablit également la valeur par défaut.
Profils : openclaw vs user
Section intitulée « Profils : openclaw vs user »openclaw: navigateur géré et isolé (aucune extension requise).user: profil d’attachement Chrome MCP intégré pour votre vraie session Chrome connectée.
Pour les appels d’outil navigateur de l’agent :
- Par défaut : utilisez le navigateur isolé
openclaw. - Privilégiez
profile="user"lorsque les sessions de connexion existantes sont importantes et que l’utilisateur est devant l’ordinateur pour cliquer/approuver toute invite d’attachement. profileest le paramètre explicite lorsque vous souhaitez un mode de navigateur spécifique.
Définissez browser.defaultProfile: "openclaw" si vous souhaitez le mode géré par défaut.
Configuration
Section intitulée « Configuration »Les paramètres du navigateur se trouvent dans ~/.openclaw/openclaw.json.
{ browser: { enabled: true, // default: true ssrfPolicy: { // dangerouslyAllowPrivateNetwork: true, // opt in only for trusted private-network access // allowPrivateNetwork: true, // legacy alias // hostnameAllowlist: ["*.example.com", "example.com"], // allowedHostnames: ["localhost"], }, // cdpUrl: "http://127.0.0.1:18792", // legacy single-profile override remoteCdpTimeoutMs: 1500, // remote CDP HTTP timeout (ms) remoteCdpHandshakeTimeoutMs: 3000, // remote CDP WebSocket handshake timeout (ms) localLaunchTimeoutMs: 15000, // local managed Chrome discovery timeout (ms) localCdpReadyTimeoutMs: 8000, // local managed post-launch CDP readiness timeout (ms) actionTimeoutMs: 60000, // default browser act timeout (ms) tabCleanup: { enabled: true, // default: true idleMinutes: 120, // set 0 to disable idle cleanup maxTabsPerSession: 8, // set 0 to disable the per-session cap sweepMinutes: 5, }, defaultProfile: "openclaw", color: "#FF4500", headless: false, noSandbox: false, attachOnly: false, executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser", profiles: { openclaw: { cdpPort: 18800, color: "#FF4500" }, work: { cdpPort: 18801, color: "#0066CC", headless: true, executablePath: "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome", }, user: { driver: "existing-session", attachOnly: true, color: "#00AA00", }, brave: { driver: "existing-session", attachOnly: true, userDataDir: "~/Library/Application Support/BraveSoftware/Brave-Browser", color: "#FB542B", }, remote: { cdpUrl: "http://10.0.0.42:9222", color: "#00AA00" }, }, },}Ports et accessibilité
- Le service de contrôle se lie à la boucle locale sur un port dérivé de
gateway.port(par défaut18791= passerelle + 2). Le remplacement degateway.portouOPENCLAW_GATEWAY_PORTdécale les ports dérivés dans la même famille. - Les profils
openclawlocaux attribuent automatiquementcdpPort/cdpUrl; ne définissez ceux-ci que pour le CDP distant.cdpUrlprend par défaut le port CDP local géré lorsqu’il n’est pas défini. remoteCdpTimeoutMss’applique aux vérifications de disponibilité HTTP CDP distantes etattachOnlyet aux requêtes HTTP d’ouverture d’onglet ;remoteCdpHandshakeTimeoutMss’applique à leurs poignées de main (handshakes) WebSocket CDP.localLaunchTimeoutMsest le budget pour un processus Chrome géré lancé localement pour exposer son point de terminaison HTTP CDP.localCdpReadyTimeoutMsest le budget de suivi pour la préparation du websocket CDP après la découverte du processus. Augmentez ces valeurs sur Raspberry Pi, VPS bas de gamme, ou ancien matériel où Chromium démarre lentement. Les valeurs doivent être des entiers positifs jusqu’à120000ms ; les valeurs de configuration invalides sont rejetées.- Les échecs répétés de lancement/préparation du Chrome géré sont désactivés (circuit-broken) par profil. Après plusieurs échecs consécutifs, OpenClaw met en pause brièvement les nouvelles tentatives de lancement au lieu de générer Chromium à chaque appel d’outil de navigation. Corrigez le problème de démarrage, désactivez le navigateur s’il n’est pas nécessaire, ou redémarrez le Gateway après réparation.
actionTimeoutMsest le budget par défaut pour les requêtes deactdu navigateur lorsque l’appelant ne passe pastimeoutMs. Le transport client ajoute une petite fenêtre de délai pour que les longues attentes puissent se terminer au lieu d’expirer à la limite HTTP.tabCleanupest un nettoyage de meilleure effort pour les onglets ouverts par les sessions de navigateur de l’agent principal. Le nettoyage du cycle de vie du sous-agent, du cron et de l’ACP ferme toujours leurs onglets suivis explicites à la fin de la session ; les sessions principales gardent les onglets actifs réutilisables, puis ferment les onglets suivis inactifs ou excédentaires en arrière-plan.
Stratégie SSRF
- La navigation du navigateur et l’ouverture d’onglets sont protégées contre les SSRF avant la navigation et vérifiées au mieux sur l’URL finale
http(s)par la suite. - En mode SSRF strict, la découverte du point de terminaison CDP distant et les sondes
/json/version(cdpUrl) sont également vérifiées. - Les variables d’environnement Gateway/provider
HTTP_PROXY,HTTPS_PROXY,ALL_PROXYetNO_PROXYne proxient pas automatiquement le navigateur géré par OpenClaw. Chrome géré se lance directement par défaut, donc les paramètres de proxy du provider ne affaiblissent pas les vérifications SSRF du navigateur. - Pour proxier le navigateur géré lui-même, passez des indicateurs de proxy Chrome explicites via
browser.extraArgs, tels que--proxy-server=...ou--proxy-pac-url=.... Le mode SSRF strict bloque le routage de proxy de navigateur explicite, sauf si l’accès au navigateur sur le réseau privé est intentionnellement activé. browser.ssrfPolicy.dangerouslyAllowPrivateNetworkest désactivé par défaut ; à activer uniquement lorsque l’accès au navigateur sur le réseau privé est intentionnellement approuvé.browser.ssrfPolicy.allowPrivateNetworkreste pris en charge en tant qu’alias hérité.
Comportement du profil
attachOnly: truesignifie ne jamais lancer de navigateur local ; s’attacher uniquement si un navigateur est déjà en cours d’exécution.headlesspeut être défini globalement ou par profil local géré. Les valeurs par profil remplacentbrowser.headless, de sorte qu’un profil lancé localement peut rester headless tandis qu’un autre reste visible.POST /start?headless=trueetopenclaw browser start --headlessdemandent un lancement headless ponctuel pour les profils locaux gérés sans réécrirebrowser.headlessou la configuration du profil. Les profils de session existante, attachement uniquement et CDP distant rejettent le remplacement car OpenClaw ne lance pas ces processus de navigateur.- Sur les hôtes Linux sans
DISPLAYniWAYLAND_DISPLAY, les profils locaux gérés passent automatiquement en mode headless lorsque ni l’environnement ni la configuration de profil/globale ne choisit explicitement le mode avec interface.openclaw browser status --jsonrapporteheadlessSourcecommeenv,profile,config,request,linux-display-fallback, oudefault. OPENCLAW_BROWSER_HEADLESS=1force les lancements locaux gérés en mode headless pour le processus actuel.OPENCLAW_BROWSER_HEADLESS=0force le mode avec interface pour les démarrages ordinaires et renvoie une erreur exploitable sur les hôtes Linux sans serveur d’affichage ; une demande explicitestart --headlessprime tout de même pour ce lancement.executablePathpeut être défini globalement ou par profil local géré. Les valeurs par profil remplacentbrowser.executablePath, de sorte que différents profils gérés peuvent lancer différents navigateurs basés sur Chromium. Les deux formes acceptent~pour votre répertoire personnel du système d’exploitation.color(niveau supérieur et par profil) teinte l’interface du navigateur afin que vous puissiez voir quel profil est actif.- Le profil par défaut est
openclaw(autonome géré). UtilisezdefaultProfile: "user"pour opter pour le navigateur de l’utilisateur connecté. - Ordre de détection automatique : navigateur par défaut du système s’il est basé sur Chromium ; sinon Chrome → Brave → Edge → Chromium → Chrome Canary.
driver: "existing-session"utilise Chrome DevTools MCP au lieu du CDP brut. Ne définissez pascdpUrlpour ce pilote.- Définissez `browser.profiles.
.userDataDirlorsqu'un profil de session existante doit s'attacher à un profil utilisateur Chromium non par défaut (Brave, Edge, etc.). Ce chemin accepte également~` pour votre répertoire personnel du système d’exploitation.
Utilisez Brave ou un autre navigateur basé sur Chromium
Section intitulée « Utilisez Brave ou un autre navigateur basé sur Chromium »Si votre navigateur par défaut du système est basé sur Chromium (Chrome/Brave/Edge/etc.),
OpenClaw l’utilise automatiquement. Définissez browser.executablePath pour remplacer
la détection automatique. Les valeurs executablePath de niveau supérieur et par profil acceptent ~
pour votre répertoire personnel du système d’exploitation :
openclaw config set browser.executablePath "/usr/bin/google-chrome"openclaw config set browser.profiles.work.executablePath "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"Ou définissez-le dans la configuration, par plateforme :
{ browser: { executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser", },}{ browser: { executablePath: "C:\\Program Files\\BraveSoftware\\Brave-Browser\\Application\\brave.exe", },}{ browser: { executablePath: "/usr/bin/brave-browser", },}Le executablePath par profil n’affecte que les profils gérés localement que OpenClaw
lance. Les profils existing-session se connectent plutôt à un navigateur déjà en cours d’exécution,
et les profils CDP distants utilisent le navigateur situé derrière cdpUrl.
Contrôle local vs distant
Section intitulée « Contrôle local vs distant »- Contrôle local (par défaut) : le Gateway démarre le service de contrôle de boucle locale et peut lancer un navigateur local.
- Contrôle distant (hôte de nœud) : exécutez un hôte de nœud sur la machine qui dispose du navigateur ; le Gateway y transfère les actions du navigateur.
- CDP distant : définissez
browser.profiles.<name>.cdpUrl(oubrowser.cdpUrl) pour vous connecter à un navigateur distant basé sur Chromium. Dans ce cas, OpenClaw ne lancera pas de navigateur local. - Pour les services CDP gérés en externe sur la boucle locale (par exemple Browserless dans
Docker publié sur
127.0.0.1), définissez égalementattachOnly: true. Le CDP de boucle locale sansattachOnlyest traité comme un profil de navigateur géré localement par OpenClaw. headlessn’affecte que les profils gérés localement que OpenClaw lance. Cela ne redémarre pas ni ne modifie les navigateurs CDP distants ou de session existante.executablePathsuit la même règle de profil géré localement. Le modifier sur un profil géré localement en cours d’exécution marque ce profil pour redémarrage/réconciliation afin que le prochain lancement utilise le nouveau binaire.
Le comportement d’arrêt diffère selon le mode de profil :
- profils gérés localement :
openclaw browser stoparrête le processus du navigateur que OpenClaw a lancé - les profils attach-only et CDP distants :
openclaw browser stopferme la session de contrôle active et libère les remplacements d’émulation Playwright/CDP (viewport, schéma de couleurs, paramètres régionaux, fuseau horaire, mode hors ligne et états similaires), même si aucun processus de navigateur n’a été lancé par OpenClaw
Les URL CDP distantes peuvent inclure une authentification :
- Jetons de requête (par exemple,
https://provider.example?token=<token>) - Authentification HTTP Basic (par exemple,
https://user:[email protected])
OpenClaw préserve l’authentification lors de l’appel aux points de terminaison /json/* et lors de la connexion au WebSocket CDP. Privilégiez les variables d’environnement ou les gestionnaires de secrets pour les jetons plutôt que de les valider dans les fichiers de configuration.
Proxy de navigateur de nœud (par défaut sans configuration)
Section intitulée « Proxy de navigateur de nœud (par défaut sans configuration) »Si vous exécutez un hôte de nœud sur la machine qui possède votre navigateur, OpenClaw peut acheminer automatiquement les appels d’outil de navigateur vers ce nœud sans aucune configuration supplémentaire du navigateur. C’est le chemin par défaut pour les passerelles distantes.
Notes :
- L’hôte de nœud expose son serveur de contrôle de navigateur local via une commande de proxy.
- Les profils proviennent de la propre configuration
browser.profilesdu nœud (identique à la configuration locale). nodeHost.browserProxy.allowProfilesest facultatif. Laissez-le vide pour le comportement hérité par défaut : tous les profils configurés restent accessibles via le proxy, y compris les routes de création/suppression de profils.- Si vous définissez
nodeHost.browserProxy.allowProfiles, OpenClaw le traite comme une limite de moindre privilège : seuls les profils autorisés peuvent être ciblés, et les routes de création/suppression de profils persistants sont bloquées sur la surface du proxy. - Désactivez-le si vous ne le souhaitez pas :
- Sur le nœud :
nodeHost.browserProxy.enabled=false - Sur la passerelle :
gateway.nodes.browser.mode="off"
- Sur le nœud :
Browserless (CDP distant hébergé)
Section intitulée « Browserless (CDP distant hébergé) »Browserless est un service Chromium hébergé qui expose des URL de connexion CDP via HTTPS et WebSocket. OpenClaw peut utiliser l’une ou l’autre forme, mais pour un profil de navigateur distant, l’option la plus simple est l’URL WebSocket directe issue de la documentation de connexion de Browserless.
Exemple :
{ browser: { enabled: true, defaultProfile: "browserless", remoteCdpTimeoutMs: 2000, remoteCdpHandshakeTimeoutMs: 4000, profiles: { browserless: { cdpUrl: "wss://production-sfo.browserless.io?token=<BROWSERLESS_API_KEY>", color: "#00AA00", }, }, },}Notes :
- Remplacez
<BROWSERLESS_API_KEY>par votre véritable jeton Browserless. - Choisissez le point de terminaison régional qui correspond à votre compte Browserless (voir leur documentation).
- Si Browserless vous fournit une URL de base HTTPS, vous pouvez soit la convertir en
wss://pour une connexion CDP directe, soit conserver l’URL HTTPS et laisser OpenClaw découvrir/json/version.
Browserless Docker sur le même hôte
Section intitulée « Browserless Docker sur le même hôte »Lorsque Browserless est auto-hébergé dans Docker et qu’OpenClaw s’exécute sur l’hôte, traitez Browserless comme un service CDP géré en externe :
{ browser: { enabled: true, defaultProfile: "browserless", profiles: { browserless: { cdpUrl: "ws://127.0.0.1:3000", attachOnly: true, color: "#00AA00", }, }, },}L’adresse dans browser.profiles.browserless.cdpUrl doit être accessible depuis le processus
OpenClaw. Browserless doit également annoncer un point de terminaison correspondant et accessible ;
définissez EXTERNAL de Browserless sur cette même base WebSocket publique pour OpenClaw, telle
que ws://127.0.0.1:3000, ws://browserless:3000, ou une adresse réseau privée stable de
Docker. Si /json/version renvoie webSocketDebuggerUrl pointant vers
une adresse que OpenClaw ne peut pas atteindre, le HTTP CDP peut sembler sain alors que la connexion
WebSocket échoue toujours.
Ne laissez pas attachOnly non défini pour un profil Browserless de bouclage. Sans
attachOnly, OpenClaw traite le port de bouclage comme un profil de navigateur géré localement
et peut signaler que le port est utilisé mais n’est pas possédé par OpenClaw.
Fournisseurs CDP WebSocket directs
Section intitulée « Fournisseurs CDP WebSocket directs »Certains services de navigateur hébergés exposent un point de terminaison WebSocket direct plutôt que
la découverte CDP standard basée sur HTTP (/json/version). OpenClaw accepte trois
formes d’URL CDP et choisit automatiquement la bonne stratégie de connexion :
- Découverte HTTP(S) -
http://host[:port]ouhttps://host[:port]. OpenClaw appelle/json/versionpour découvrir l’URL du débogueur WebSocket, puis se connecte. Pas de repli WebSocket. - Points de terminaison WebSocket directs -
ws://host[:port]/devtools/<kind>/<id>ouwss://...avec un chemin/devtools/browser|page|worker|shared_worker|service_worker/<id>. OpenClaw se connecte directement via une poignée de main WebSocket et ignore entièrement/json/version. - Racines WebSocket nues -
ws://host[:port]ouwss://host[:port]sans chemin/devtools/...(par ex. Browserless, Browserbase). OpenClaw essaie d’abord la découverte HTTP/json/version(en normalisant le schéma enhttp/https) ; si la découverte renvoie unwebSocketDebuggerUrl, celui-ci est utilisé, sinon OpenClaw revient à une poignée de main WebSocket directe à la racine nue. Si le point de terminaison WebSocket annoncé refuse la poignée de main CDP mais que la racine nue configurée l’accepte, OpenClaw revient également à cette racine. Cela permet à unws://nu pointant vers un Chrome local de se connecter, car Chrome n’accepte les mises à niveau WebSocket que sur le chemin spécifique par cible issu de/json/version, tandis que les fournisseurs hébergés peuvent toujours utiliser leur point de terminaison WebSocket racine lorsque leur point de terminaison de découverte annonce une URL éphémère qui n’est pas adaptée au CDP de Playwright.
Browserbase
Section intitulée « Browserbase »Browserbase est une plate-forme cloud pour exécuter des navigateurs headless avec résolution intégrée de CAPTCHA, mode furtif et proxys résidentiels.
{ browser: { enabled: true, defaultProfile: "browserbase", remoteCdpTimeoutMs: 3000, remoteCdpHandshakeTimeoutMs: 5000, profiles: { browserbase: { cdpUrl: "wss://connect.browserbase.com?apiKey=<BROWSERBASE_API_KEY>", color: "#F97316", }, }, },}Notes :
- Inscrivez-vous et copiez votre clé API à partir du tableau de bord de présentation.
- Remplacez
<BROWSERBASE_API_KEY>par votre vraie clé API Browserbase. - Browserbase crée automatiquement une session de navigateur lors de la connexion WebSocket, donc aucune étape de création de session manuelle n’est nécessaire.
- Le niveau gratuit permet une session simultanée et une heure de navigateur par mois. Consultez la tarification pour les limites des plans payants.
- Consultez la documentation Browserbase pour une référence complète de l’API, les guides SDK et les exemples d’intégration.
Sécurité
Section intitulée « Sécurité »Idées clés :
- Le contrôle du navigateur s’effectue uniquement en boucle locale (loopback) ; l’accès transite par l’authentification ou le jumelage de nœuds du Gateway.
- L’API HTTP du navigateur en boucle locale autonome utilise uniquement l’authentification par secret partagé :
authentification du porteur par jeton de passerelle,
x-openclaw-password, ou authentification HTTP Basic avec le mot de passe de passerelle configuré. - Les en-têtes d’identité Tailscale Serve et
gateway.auth.mode: "trusted-proxy"n’authentifient pas cette API de navigateur bouclage autonome. - Si le contrôle du navigateur est activé et qu’aucune authentification par secret partagé n’est configurée, OpenClaw génère un jeton de passerelle exclusif à l’exécution pour ce démarrage. Configurez
gateway.auth.token,gateway.auth.password,OPENCLAW_GATEWAY_TOKENouOPENCLAW_GATEWAY_PASSWORDexplicitement si les clients ont besoin d’un secret stable entre les redémarrages. - OpenClaw ne génère pas automatiquement ce jeton lorsque
gateway.auth.modeest déjàpassword,noneoutrusted-proxy. - Gardez la Gateway et tous les hôtes de nœuds sur un réseau privé (Tailscale) ; évitez l’exposition publique.
- Traitez les URL/jetons CDP distants comme des secrets ; préférez les env vars ou un gestionnaire de secrets.
Conseils pour le CDP distant :
- Préférez les points de terminaison chiffrés (HTTPS ou WSS) et les jetons à courte durée de vie lorsque cela est possible.
- Évitez d’intégrer des jetons à longue durée de vie directement dans les fichiers de configuration.
Profils (multi-navigateur)
Section intitulée « Profils (multi-navigateur) »OpenClaw prend en charge plusieurs profils nommés (configurations de routage). Les profils peuvent être :
- openclaw-managed : une instance de navigateur basée sur Chromium dédiée avec son propre répertoire de données utilisateur + port CDP
- remote : une URL CDP explicite (navigateur basé sur Chromium s’exécutant ailleurs)
- existing session : votre profil Chrome existant via Chrome DevTools MCP auto-connect
Valeurs par défaut :
- Le profil
openclawest créé automatiquement s’il est manquant. - Le profil
userest intégré pour l’attachement à une session existante Chrome MCP. - Les profils de session existante sont optionnels au-delà de
user; créez-les avec--driver existing-session. - Les ports CDP locaux sont alloués à partir de 18800-18899 par défaut.
- La suppression d’un profil déplace son répertoire de données locales vers la Corbeille.
Tous les points de terminaison de contrôle acceptent ?profile=<name> ; le CLI utilise --browser-profile.
Session existante via Chrome DevTools MCP
Section intitulée « Session existante via Chrome DevTools MCP »OpenClaw peut également s’attacher à un profil de navigateur basé sur Chromium en cours d’exécution via le serveur officiel Chrome DevTools MCP. Cela réutilise les onglets et l’état de connexion déjà ouverts dans ce profil de navigateur.
Références officielles pour le contexte et la configuration :
- Chrome pour les développeurs : Utiliser Chrome DevTools MCP avec votre session de navigateur
- README de Chrome DevTools MCP
Profil intégré :
user
Facultatif : créez votre propre profil de session existante personnalisé si vous souhaitez un nom, une couleur ou un répertoire de données de navigateur différent.
Comportement par défaut :
- Le profil intégré
userutilise la connexion automatique Chrome MCP, qui cible le profil Google Chrome local par défaut.
Utilisez userDataDir pour Brave, Edge, Chromium, ou un profil Chrome non par défaut.
~ s’étend au répertoire personnel de votre système d’exploitation :
{ browser: { profiles: { brave: { driver: "existing-session", attachOnly: true, userDataDir: "~/Library/Application Support/BraveSoftware/Brave-Browser", color: "#FB542B", }, }, },}Ensuite, dans le navigateur correspondant :
- Ouvrez la page d’inspection de ce navigateur pour le débogage à distance.
- Activez le débogage à distance.
- Gardez le navigateur ouvert et approuvez la demande de connexion lorsque OpenClaw s’attache.
Pages d’inspection courantes :
- Chrome :
chrome://inspect/#remote-debugging - Brave : Brave :
brave://inspect/#remote-debugging - Edge :
edge://inspect/#remote-debugging
Test de fumée d’attachement en direct :
openclaw browser --browser-profile user startopenclaw browser --browser-profile user statusopenclaw browser --browser-profile user tabsopenclaw browser --browser-profile user snapshot --format aiÀ quoi ressemble le succès :
statusaffichedriver: existing-sessionstatusaffichetransport: chrome-mcpstatusafficherunning: truetabsrépertorie vos onglets de navigateur déjà ouvertssnapshotrenvoie les références de l’onglet en direct sélectionné
Ce qu’il faut vérifier si l’attachement ne fonctionne pas :
- le navigateur cible basé sur Chromium est en version
144+ - le débogage à distance est activé dans la page d’inspection de ce navigateur
- le navigateur a affiché la demande et vous avez accepté la invite de consentement d’attachement
openclaw doctormigre l’ancienne configuration de navigateur basée sur les extensions et vérifie que Chrome est installé localement pour les profils de connexion automatique par défaut, mais il ne peut pas activer le débogage à distance du côté du navigateur pour vous
Utilisation par l’agent :
- Utilisez
profile="user"lorsque vous avez besoin de l’état du navigateur connecté de l’utilisateur. - Si vous utilisez un profil de session existante personnalisé, transmettez ce nom de profil explicite.
- Choisissez ce mode uniquement lorsque l’utilisateur est devant l’ordinateur pour approuver la invite d’attachement.
- le Gateway ou l’hôte du nœud peut générer
npx chrome-devtools-mcp@latest --autoConnect
Notes :
- Cette méthode présente un risque plus élevé que le profil isolé
openclawcar elle peut agir au sein de votre session de navigateur connectée. - OpenClaw ne lance pas le navigateur pour ce pilote ; il s’attache uniquement.
- OpenClaw utilise ici le flux officiel
--autoConnectde Chrome DevTools MCP. SiuserDataDirest défini, il est transmis pour cibler ce répertoire de données utilisateur. - La session existante peut s’attacher à l’hôte sélectionné ou via un nœud de navigateur connecté. Si Chrome se trouve ailleurs et qu’aucun nœud de navigateur n’est connecté, utilisez plutôt le CDP distant ou un hôte de nœud.
Lancement personnalisé du Chrome MCP
Section intitulée « Lancement personnalisé du Chrome MCP »Remplacez le serveur Chrome DevTools MCP généré par profil lorsque le flux npx chrome-devtools-mcp@latest par défaut
n’est pas celui souhaité (hôtes hors ligne,
versions épinglées, binaires intégrés) :
| Champ | Ce qu’il fait |
|---|---|
mcpCommand | Exécutable à générer à la place de npx. Résolu tel quel ; les chemins absolus sont respectés. |
mcpArgs | Tableau d’arguments passé tel quel à mcpCommand. Remplace les arguments chrome-devtools-mcp@latest --autoConnect par défaut. |
Lorsque cdpUrl est défini sur un profil de session existante, OpenClaw ignore
--autoConnect et transfère automatiquement le point de terminaison à Chrome MCP :
http(s)://...→--browserUrl <url>(point de terminaison de découverte HTTP DevTools).ws(s)://...→--wsEndpoint <url>(WebSocket CDP direct).
Les indicateurs de point de terminaison et userDataDir ne peuvent pas être combinés : lorsque cdpUrl est défini,
userDataDir est ignoré pour le lancement de Chrome MCP, car Chrome MCP s’attache au
navigateur en cours d’exécution derrière le point de terminaison plutôt que d’ouvrir un répertoire
de profil.
Limitations des fonctionnalités de session existante
Par rapport au profil openclaw géré, les pilotes de session existante sont plus limités :
- Captures d’écran - les captures de page et les captures d’élément
--reffonctionnent ; les sélecteurs CSS--elementne fonctionnent pas.--full-pagene peut pas être combiné avec--refou--element. Playwright n’est pas requis pour les captures d’écran de page ou d’élément basées sur une référence. - Actions -
click,type,hover,scrollIntoView,dragetselectnécessitent des références d’instantané (pas de sélecteurs CSS).click-coordsclique sur les coordonnées visibles de la fenêtre d’affichage et ne nécessite pas de référence d’instantané.clickconcerne uniquement le bouton gauche.typene prend pas en chargeslowly=true; utilisezfilloupress.pressne prend pas en chargedelayMs.type,hover,scrollIntoView,drag,select,filletevaluatene prennent pas en charge les délais d’attente par appel.selectaccepte une seule valeur. - Attente / téléchargement / boîte de dialogue -
wait --urlprend en charge les modèles exacts, de sous-chaîne et globaux ;wait --load networkidlen’est pas pris en charge. Les hooks de téléchargement nécessitentrefouinputRef, un fichier à la fois, sans CSSelement. Les hooks de boîte de dialogue ne prennent pas en charge les remplacements de délai d’attente oudialogId. - Visibilité de la boîte de dialogue - Les réponses d’action du navigateur géré incluent
blockedByDialogetbrowserState.dialogs.pendinglorsqu’une action ouvre une boîte de dialogue modale ; les instantanés incluent également l’état de la boîte de dialogue en attente. Répondez avec `browser dialog —accept/—dismiss —dialog-id
tant qu'une boîte de dialogue est en attente. Les boîtes de dialogue gérées en dehors d'OpenClaw apparaissent sousbrowserState.dialogs.recent`.
- Fonctionnalités gérées uniquement - les actions par lot, l’exportation PDF, l’interception de téléchargement et
responsebodynécessitent toujours le chemin du navigateur géré.
Garanties d’isolement
Section intitulée « Garanties d’isolement »- Répertoire de données utilisateur dédié : ne touche jamais votre profil de navigateur personnel.
- Ports dédiés : évite
9222pour éviter les collisions avec les flux de travail de développement. - Contrôle déterministe des onglets :
tabsrenvoie d’abordsuggestedTargetId, puis des handlestabIdstables tels quet1, des étiquettes optionnelles, et letargetIdbrut. Les agents doivent réutilisersuggestedTargetId; les identifiants bruts restent disponibles pour le débogage et la compatibilité.
Sélection du navigateur
Section intitulée « Sélection du navigateur »Lors du lancement en local, OpenClaw choisit le premier disponible :
- Chrome
- Brave
- Edge
- Chromium
- Chrome Canary
Vous pouvez remplacer avec browser.executablePath.
Plateformes :
- macOS : vérifie
/Applicationset~/Applications. - Linux : vérifie les emplacements Chrome/Brave/Edge/Chromium courants sous
/usr/bin,/snap/bin,/opt/google,/opt/brave.com,/usr/lib/chromiumet/usr/lib/chromium-browser, plus le Chromium géré par Playwright sousPLAYWRIGHT_BROWSERS_PATHou~/.cache/ms-playwright. - Windows : vérifie les emplacements d’installation courants.
API de contrôle (optionnelle)
Section intitulée « API de contrôle (optionnelle) »Pour le scriptage et le débogage, le GatewayAPI expose une petite API de contrôle HTTP
boucle locale uniquement ainsi qu’une CLIAPI openclaw browser correspondante (instantanés, références, améliorations d’attente,
sortie JSON, flux de travail de débogage). Voir
API de contrôle du navigateur pour la référence complète.
Dépannage
Section intitulée « Dépannage »Pour les problèmes spécifiques à Linux (notamment le snap Chromium), voir Dépannage du navigateur.
Pour les configurations split-host avec WSL2 Gateway + Chrome Windows, voir Dépannage WSL2 + Windows + Chrome distant CDP.
Échec du démarrage CDP vs blocage de navigation SSRF
Section intitulée « Échec du démarrage CDP vs blocage de navigation SSRF »Il s’agit de différentes classes d’échec et elles pointent vers différents chemins de code.
- Échec du démarrage ou de la préparation CDP signifie que OpenClaw ne peut pas confirmer que le plan de contrôle du navigateur est en bonne santé.
- Blocage de navigation SSRF signifie que le plan de contrôle du navigateur est en bonne santé, mais qu’une cible de navigation de page est rejetée par la stratégie.
Exemples courants :
- Échec du démarrage ou de la préparation CDP :
Chrome CDP websocket for profile "openclaw" is not reachable after startRemote CDP for profile "<name>" is not reachable at <cdpUrl>Port <port> is in use for profile "<name>" but not by openclawlorsqu’un service CDP externe en boucle locale est configuré sansattachOnly: true
- Blocage de navigation SSRF :
open,navigate, snapshot, ou les flux d’ouverture d’onglet échouent avec une erreur de stratégie de navigateur/réseau, alors questartettabsfonctionnent toujours
Utilisez cette séquence minimale pour distinguer les deux :
openclaw browser --browser-profile openclaw startopenclaw browser --browser-profile openclaw tabsopenclaw browser --browser-profile openclaw open https://example.comComment lire les résultats :
- Si
startéchoue avecnot reachable after start, dépannez d’abord la disponibilité du CDP. - Si
startréussit mais quetabséchoue, le plan de contrôle est encore défaillant. Traitez cela comme un problème d’accessibilité CDP, et non comme un problème de navigation de page. - Si
startettabsréussissent mais queopenounavigateéchoue, le plan de contrôle du navigateur est opérationnel et l’échec provient de la stratégie de navigation ou de la page cible. - Si
start,tabsetopenréussissent tous, le chemin de contrôle de base du navigateur géré est sain.
Détails importants du comportement :
- La configuration du navigateur par défaut correspond à un objet de stratégie SSRF fermée par défaut, même lorsque vous ne configurez pas
browser.ssrfPolicy. - Pour le profil géré
openclawde local loopback, les contrôles de santé du CDP omettent intentionnellement l’application de l’accessibilité SSRF du navigateur pour le propre plan de contrôle local d’OpenClaw. - La protection de la navigation est distincte. Un résultat
startoutabsréussi ne signifie pas qu’une cibleopenounavigateultérieure est autorisée.
Conseils de sécurité :
- Ne relâchez pas la stratégie SSRF du navigateur par défaut.
- Préférez des exceptions d’hôte restreintes telles que
hostnameAllowlistouallowedHostnamesplutôt qu’un accès large au réseau privé. - Utilisez
dangerouslyAllowPrivateNetwork: trueuniquement dans des environnements approuvés par intention où l’accès du navigateur au réseau privé est requis et révisé.
Outils de l’agent + fonctionnement du contrôle
Section intitulée « Outils de l’agent + fonctionnement du contrôle »L’agent dispose d’un seul outil pour l’automatisation du navigateur :
browser- doctor/status/start/stop/tabs/open/focus/close/snapshot/screenshot/navigate/act
Comment cela correspond :
browser snapshotrenvoie une arborescence d’interface utilisateur stable (AI ou ARIA).browser actutilise les ID derefdu snapshot pour cliquer/tirer/glisser/sélectionner.browser screenshotcapture les pixels (page entière, élément ou références étiquetées).browser doctorGateway vérifie la disponibilité du Gateway, du plugin, du profil, du navigateur et de l’onglet.browseraccepte :profilepour choisir un profil de navigateur nommé (openclaw, chrome ou CDP distant).target(sandbox|host|node) pour sélectionner l’emplacement du navigateur.- Dans les sessions sandboxed,
target: "host"nécessiteagents.defaults.sandbox.browser.allowHostControl=true. - Si
targetest omis : les sessions sandboxed utilisent par défautsandbox, les sessions non-sandbox utilisent par défauthost. - Si un nœud compatible navigateur est connecté, l’outil peut automatiquement s’y router, sauf si vous épinglez
target="host"outarget="node".
Cela rend l’agent déterministe et évite les sélecteurs fragiles.
Connexes
Section intitulée « Connexes »- Aperçu des outils - tous les outils d’agent disponibles
- Sandboxing - contrôle du navigateur dans les environnements sandboxed
- Sécurité - risques et durcissement du contrôle du navigateur