# Headless Browser

Headless Browser permite executar e controlar uma experiência remota de navegação headless sem a complexidade de gerenciá-la localmente ou na sua própria infraestrutura. Ele oferece uma forma simples de executar automação baseada em navegador, testes e web scraping sem lidar com configuração do navegador, limitações de recursos ou desafios de detecção.&#x20;

### Bibliotecas compatíveis

Headless Browser funciona com qualquer biblioteca que suporte o **Chrome DevTools Protocol (CDP)**. Isso inclui:

* [Playwright](https://playwright.dev/) (para Firefox, as versões compatíveis do Playwright são 1.51 e 1.56)
* [Puppeteer](https://pptr.dev/)
* Outros frameworks de automação compatíveis com CDP

### Opções de navegador

Headless Browser oferece dois ambientes de navegador especializados:

* [navegador baseado em Chrome](/products/pt-br/headless-browser/chrome.md) – navegadores remotos de alto desempenho com stealth avançado, executados em servidores dedicados com proxies integrados
* [navegador baseado em Firefox](/products/pt-br/headless-browser/firefox.md) (Legado) - implementação do Firefox com recursos antidetecção integrados e integração com proxy. Observe que este ambiente será descontinuado em breve.

Além disso, Headless Browser permite duas funcionalidades relacionadas à localização:

* Otimização de desempenho para usuários baseados nos EUA,
* Parâmetros de geolocalização para segmentação por país, cidade e estado.

### **Limites de taxa**

Cada um tem **100 sessões concorrentes** e pode iniciar até **10 sessões por segundo para cada navegador** (Chrome e Firefox). Isso garante a estabilidade e o desempenho do serviço.

Para solicitar um limite maior para sua conta, entre em contato com o Suporte ao Cliente da Oxylabs via [chat ao vivo](https://oxylabs.io/) ou [e-mail](mailto:support@oxylabs.io).

### Exemplos de início rápido

{% tabs %}
{% tab title="Python" %}

```python
from playwright.sync_api import sync_playwright

username = "your-username"
password = "your-password"
endpoint = "ubc.oxylabs.io"
browser_url = f"wss://{username}:{password}@{endpoint}"

with sync_playwright() as p:
    browser = p.chromium.connect_over_cdp(browser_url)
    page = browser.new_page()
    page.goto('https://example.com')
    print(page.title())
    browser.close()
```

{% endtab %}

{% tab title="JavaScript (Playwright)" %}

```javascript
import { chromium } from 'playwright';

(async () => {
    const username = 'your-username';
    const password = 'your-password';
    const endpoint = 'ubc.oxylabs.io';
    const browserUrl = `wss://${username}:${password}@${endpoint}`;

    const browser = await chromium.connectOverCDP(browserUrl);
    const page = await browser.newPage();
    await page.goto('https://example.com');
    console.log(await page.title());
    await browser.close();
})();
```

{% endtab %}

{% tab title="JavaScript (Puppeteer)" %}

```javascript
import puppeteer from 'puppeteer';

(async () => {
  const username = 'your-username';
  const password = 'your-password';
  const endpoint = 'ubc.oxylabs.io';
  const browserUrl = `wss://${username}:${password}@${endpoint}`;

  const browser = await puppeteer.connect({
    browserWSEndpoint: browserUrl
  });
  const page = await browser.newPage();
  await page.goto('https://example.com');
  console.log(await page.title());
  await browser.close();
})();
```

{% endtab %}
{% endtabs %}


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://developers.oxylabs.io/products/pt-br/headless-browser.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
