Modalità headless di Chrome

Peter Kvitek
Peter Kvitek

Con la modalità Chrome Headless, puoi eseguire il browser in un ambiente senza supervisione, senza alcuna UI visibile. Essenzialmente, puoi eseguire Chrome senza Chrome.

La modalità headless è una scelta molto diffusa per l'automazione del browser, tramite progetti come Puppeteer o ChromeDriver.

Usa la modalità headless

Per utilizzare la modalità headless, passa il flag della riga di comando --headless:

chrome --headless

Utilizzare la vecchia modalità headless

In precedenza, la modalità headless era un'implementazione separata del browser alternativo che veniva spedita come parte dello stesso programma binario di Chrome. Non ha condiviso nessuno del codice del browser Chrome in //chrome.

Ora Chrome ha modalità headless e headful unificate.

La modalità headless condivide il codice con Chrome.

Per il momento, la vecchia modalità headless è ancora disponibile con:

chrome --headless=old

In Puppeteer

Per usare la modalità headless in Puppeteer:

import puppeteer from 'puppeteer';

const browser = await puppeteer.launch({
  headless: 'true', // (default) enables Headless
  // `headless: 'old'` enables old Headless
  // `headless: false` enables "headful" mode
});

const page = await browser.newPage();
await page.goto('https://developer.chrome.com/');

// …

await browser.close();

In Selenium-WebDriver

Per utilizzare la modalità headless in Selenium-WebDriver:

const driver = await env
  .builder()
  .setChromeOptions(options.addArguments('--headless'))
  .build();

await driver.get('https://developer.chrome.com/');

// …

await driver.quit();

Per ulteriori informazioni, inclusi esempi che utilizzano altre associazioni di linguaggi, consulta il post del blog del team di Selenium.

Flag della riga di comando

I seguenti flag della riga di comando sono disponibili in modalità headless.

--dump-dom

Il flag --dump-dom stampa il DOM serializzato della pagina di destinazione su stdout. Ad esempio:

chrome --headless --dump-dom https://developer.chrome.com/

Questo è diverso dalla stampa del codice sorgente HTML, che potresti eseguire con curl. Per generare l'output di --dump-dom, Chrome analizza innanzitutto il codice HTML in un DOM, esegue eventuali --dump-dom che potrebbero alterare il DOM e poi trasforma nuovamente il DOM in una stringa di HTML serializzata.<script>

--screenshot

Il flag --screenshot acquisisce uno screenshot della pagina di destinazione e lo salva come screenshot.png nella directory di lavoro corrente. Questa opzione è particolarmente utile in combinazione con il flag --window-size.

Ad esempio:

chrome --headless --screenshot --window-size=412,892 https://developer.chrome.com/

--print-to-pdf

Il flag --print-to-pdf salva la pagina di destinazione come PDF denominato output.pdf nella directory di lavoro corrente. Ad esempio:

chrome --headless --print-to-pdf https://developer.chrome.com/

Se vuoi, puoi aggiungere il flag --no-pdf-header-footer per omettere l'intestazione di stampa (con la data e l'ora correnti) e il piè di pagina (con l'URL e il numero di pagina).

chrome --headless --print-to-pdf --no-pdf-header-footer https://developer.chrome.com/

Nota: la funzionalità alla base del flag --no-pdf-header-footer era precedentemente disponibile con il flag --print-to-pdf-no-header. Se utilizzi una versione precedente, potrebbe essere necessario tornare al nome del vecchio indicatore.

--timeout

Il flag --timeout definisce il tempo di attesa massimo (in millisecondi) dopo il quale i contenuti della pagina vengono acquisiti da --dump-dom, --screenshot e --print-to-pdf anche se la pagina è ancora in fase di caricamento.

chrome --headless --print-to-pdf --timeout=5000 https://developer.chrome.com/

Il flag --timeout=5000 indica a Chrome di attendere fino a 5 secondi prima di stampare il PDF. Pertanto, l'esecuzione di questa procedura richiede al massimo 5 secondi.

--virtual-time-budget

--virtual-time-budget agisce come "avanzamento veloce" per qualsiasi codice dipendente dal tempo (ad esempio setTimeout/setInterval). Costringe il browser a eseguire qualsiasi del codice della pagina il più rapidamente possibile facendo credere alla pagina che il tempo passi effettivamente.

Per illustrarne l'utilizzo, considera questa demo, che incrementa, registra e mostra un contatore ogni secondo utilizzando setTimeout(fn, 1000). Ecco il codice pertinente:

<output>0</output>
<script>
  const element = document.querySelector('output');
  let counter = 0;
  setInterval(() => {
    counter++;
    console.log(counter);
    element.textContent = counter;
  }, 1_000);
</script>

Dopo un secondo, la pagina contiene "1"; dopo due secondi, "2" e così via. Ecco come acquisire lo stato della pagina dopo 42 secondi e salvarlo come PDF:

chrome --headless --print-to-pdf --virtual-time-budget=42000 https://mathiasbynens.be/demo/time

--allow-chrome-scheme-url

Il flag --allow-chrome-scheme-url è necessario per accedere agli URL chrome://. Questo flag è disponibile da Chrome 123. Ecco un esempio:

chrome --headless --print-to-pdf --allow-chrome-scheme-url chrome://gpu

Debug

Poiché Chrome è praticamente invisibile in modalità headless, potrebbe sembrare complicato risolvere un problema. È possibile eseguire il debug di Chrome headless in un modo molto simile a Chrome con interfaccia utente.

Avvia Chrome in modalità headless con il --remote-debugging-port flag della riga di comando.

chrome --headless --remote-debugging-port=0 https://developer.chrome.com/

Viene stampato un URL WebSocket univoco su stdout, ad esempio:

DevTools listening on ws://127.0.0.1:60926/devtools/browser/b4bd6eaa-b7c8-4319-8212-225097472fd9

In un'istanza di Chrome headless, possiamo quindi utilizzare il debug remoto di Chrome DevTools per connetterci alla destinazione headless e ispezionarla.

  1. Vai a chrome://inspect e fai clic sul pulsante Configura....
  2. Inserisci l'indirizzo IP e il numero di porta dall'URL WebSocket.
    • Nell'esempio precedente ho inserito 127.0.0.1:60926.
  3. Fai clic su Fine. Dovresti vedere un oggetto target remoto con tutte le relative schede e gli altri target elencati.
  4. Fai clic su Ispeziona per accedere a Chrome DevTools e ispezionare il target headless remoto, inclusa una visualizzazione in tempo reale della pagina.

Chrome DevTools può ispezionare una pagina di destinazione headless remota

Feedback

Non vediamo l'ora di ricevere il tuo feedback sulla modalità headless. Se riscontri problemi, segnala un bug.