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. In sostanza, puoi eseguire Chrome senza Chrome.

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

Utilizzare 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 e alternativa del browser che è stata inviata come parte dello stesso programma binario di Chrome. Non ha condiviso alcun codice del browser Chrome in //chrome.

Chrome ora ha modalità headless e headful unificate.

La modalità headless condivide il codice con Chrome.

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

chrome --headless=old

In Puppeteer

Per utilizzare 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/

Questa operazione è diversa dalla stampa del codice sorgente HTML, che potresti eseguire con curl. Per fornirti l'output di --dump-dom, Chrome prima analizza il codice HTML in un DOM, esegue qualsiasi elemento <script> che potrebbe modificare il DOM, quindi trasforma quel DOM in una stringa serializzata di HTML.

--screenshot

Il flag --screenshot acquisisce uno screenshot della pagina di destinazione e lo salva come screenshot.png nella directory di lavoro attuale. 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 attuale. 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/

No: la funzionalità dietro il 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 è effettivamente invisibile in modalità headless, potrebbe sembrare difficile 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 Chrome con interfaccia utente, possiamo utilizzare il debug di Chrome DevTools da remoto per connetterci al target headless e ispezionarlo.

  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 visualizzare un 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.