Descrizione
Utilizza l'API chrome.webRequest
per osservare e analizzare il traffico e per intercettare, bloccare o modificare le richieste in transito.
Autorizzazioni
webRequest
Per utilizzare l'API per le richieste web, devi dichiarare l'autorizzazione "webRequest"
nel manifest dell'estensione, insieme alle autorizzazioni host necessarie. Per intercettare una richiesta di risorsa secondaria, l'estensione deve avere accesso sia all'URL richiesto sia al relativo iniziatore. Ad esempio:
{ "name": "My extension", ... "permissions": [ "webRequest" ], "host_permissions": [ "*://*.google.com/*" ], ... }
webRequestBlocking
Obbligatorio per registrare i gestori di eventi di blocco. A partire da Manifest V3, questa funzionalità è disponibile solo per le estensioni installate tramite criteri.
webRequestAuthProvider
Obbligatorio per utilizzare il metodo onAuthRequired
. Consulta Gestione dell'autenticazione.
Concetti e utilizzo
Ciclo di vita delle richieste
L'API per le richieste web definisce un insieme di eventi che seguono il ciclo di vita di una richiesta web. Puoi utilizzare questi eventi per osservare e analizzare il traffico. Alcuni eventi sincroni ti consentono di intercettare, bloccare o modificare una richiesta.
Il ciclo di vita degli eventi per le richieste andate a buon fine è illustrato di seguito, seguito dalle definizioni degli eventi:
onBeforeRequest
(facoltativamente sincrono)- Viene attivato quando sta per verificarsi una richiesta. Questo evento viene inviato prima che venga stabilita qualsiasi connessione TCP e può essere utilizzato per annullare o reindirizzare le richieste.
onBeforeSendHeaders
(facoltativamente sincrono)- Viene attivato quando sta per verificarsi una richiesta e le intestazioni iniziali sono state preparate. L'evento ha lo scopo di consentire alle estensioni di aggiungere, modificare ed eliminare le intestazioni delle richieste (*). L'evento
onBeforeSendHeaders
viene trasmesso a tutti gli abbonati, quindi abbonati diversi potrebbero tentare di modificare la richiesta. Per informazioni su come viene gestita questa situazione, consulta la sezione Dettagli di implementazione. Questo evento può essere utilizzato per annullare la richiesta. onSendHeaders
- Viene attivato dopo che tutte le estensioni hanno avuto la possibilità di modificare le intestazioni della richiesta e presenta la versione finale (*). L'evento viene attivato prima che le intestazioni vengano inviate alla rete. Questo evento è informativo e viene gestito in modo asincrono. Non consente la modifica o l'annullamento della richiesta.
onHeadersReceived
(facoltativamente sincrono)- Viene attivato ogni volta che viene ricevuta un'intestazione di risposta HTTP(S). A causa dei reindirizzamenti e delle richieste di autenticazione, ciò può verificarsi più volte per richiesta. Questo evento ha lo scopo di consentire alle estensioni di aggiungere, modificare ed eliminare le intestazioni di risposta, ad esempio le intestazioni Content-Type in entrata. Le direttive di memorizzazione nella cache vengono elaborate prima dell'attivazione di questo evento, quindi la modifica delle intestazioni come Cache-Control non ha alcuna influenza sulla cache del browser. Ti consente inoltre di annullare o reindirizzare la richiesta.
onAuthRequired
(facoltativamente sincrono)- Viene attivato quando una richiesta richiede l'autenticazione dell'utente. Questo evento può essere gestito in modo sincrono per fornire le credenziali di autenticazione. Tieni presente che le estensioni potrebbero fornire credenziali non valide. Fai attenzione a non entrare in un ciclo infinito fornendo ripetutamente credenziali non valide. Puoi anche utilizzarlo per annullare la richiesta.
onBeforeRedirect
- Viene attivato quando sta per essere eseguito un reindirizzamento. Un reindirizzamento può essere attivato da un codice di risposta HTTP o da un'estensione. Questo evento è informativo e viene gestito in modo asincrono. Non ti consente di modificare o annullare la richiesta.
onResponseStarted
- Viene attivato quando viene ricevuto il primo byte del corpo della risposta. Per le richieste HTTP, ciò significa che sono disponibili la riga di stato e le intestazioni della risposta. Questo evento è informativo e viene gestito in modo asincrono. Non consente di modificare o annullare la richiesta.
onCompleted
- Viene attivato quando una richiesta è stata elaborata correttamente.
onErrorOccurred
- Viene attivato quando una richiesta non può essere elaborata correttamente.
L'API Web Request garantisce che per ogni richiesta venga attivato onCompleted
o onErrorOccurred
come evento finale, con un'eccezione: se una richiesta viene reindirizzata a un URL data://
, onBeforeRedirect
è l'ultimo evento segnalato.
* Tieni presente che l'API per le richieste web presenta un'astrazione dello stack di rete all'estensione. A livello interno, una richiesta URL può essere suddivisa in più richieste HTTP (ad esempio, per recuperare singoli intervalli di byte da un file di grandi dimensioni) o può essere gestita dallo stack di rete senza comunicare con la rete. Per questo motivo, l'API non fornisce le intestazioni HTTP finali inviate alla rete. Ad esempio, tutte le intestazioni correlate alla memorizzazione nella cache sono invisibili all'estensione.
Le seguenti intestazioni non vengono attualmente fornite all'evento onBeforeSendHeaders
. Non è garantito che questo elenco sia completo o stabile.
- Autorizzazione
- Cache-Control
- Connessione
- Content-Length
- Host
- If-Modified-Since
- If-None-Match
- If-Range
- Partial-Data
- Pragma
- Proxy-Authorization
- Proxy-Connection
- Transfer-Encoding
A partire da Chrome 79, le modifiche all'intestazione della richiesta influiscono sui controlli di condivisione delle risorse tra origini (CORS). Se le intestazioni modificate per le richieste multiorigine non soddisfano i criteri, verrà inviata una richiesta preflight CORS per chiedere al server se tali intestazioni possono essere accettate. Se devi davvero modificare le intestazioni in modo da violare il protocollo CORS, devi specificare 'extraHeaders'
in opt_extraInfoSpec
. D'altra parte, le modifiche all'intestazione di risposta non funzionano per ingannare i controlli CORS. Se devi ingannare il protocollo CORS, devi anche specificare 'extraHeaders'
per le modifiche alla risposta.
A partire da Chrome 79, l'API webRequest non intercetta le richieste e le risposte preflight CORS per impostazione predefinita. Un preflight CORS per un URL richiesta è visibile a un'estensione se è presente un listener con 'extraHeaders'
specificato in opt_extraInfoSpec
per l'URL richiesta. onBeforeRequest
può anche acquisire 'extraHeaders'
da Chrome 79.
A partire da Chrome 79, la seguente intestazione della richiesta non viene fornita e non può essere modificata o rimossa senza specificare 'extraHeaders'
in opt_extraInfoSpec
:
- Origine
A partire da Chrome 72, se devi modificare le risposte prima che il blocco della lettura interorigine (CORB) possa bloccare la risposta, devi specificare 'extraHeaders'
in opt_extraInfoSpec
.
A partire da Chrome 72, le seguenti intestazioni della richiesta non vengono fornite e non possono essere modificate o rimosse senza specificare 'extraHeaders'
in opt_extraInfoSpec
:
- Accept-Language
- Accept-Encoding
- Referer
- Cookie
A partire da Chrome 72, l'intestazione della risposta Set-Cookie
non viene fornita e non può essere modificata o rimossa senza specificare 'extraHeaders'
in opt_extraInfoSpec
.
A partire da Chrome 89, l'intestazione della risposta X-Frame-Options
non può essere modificata o rimossa in modo efficace senza specificare 'extraHeaders'
in opt_extraInfoSpec
.
L'API webRequest espone solo le richieste che l'estensione è autorizzata a visualizzare, in base alle autorizzazioni host. Inoltre, sono accessibili solo i seguenti schemi: http://
, https://
, ftp://
, file://
, ws://
(a partire da Chrome 58), wss://
(a partire da Chrome 58), urn:
(a partire da Chrome 91) o chrome-extension://
. Inoltre, vengono nascoste anche alcune richieste con URL che utilizzano uno degli schemi precedenti. Questi includono chrome-extension://other_extension_id
dove other_extension_id
non è l'ID dell'estensione per gestire la richiesta, https://www.google.com/chrome
e altre richieste sensibili fondamentali per la funzionalità del browser. Inoltre, le richieste XMLHttpRequests sincrone dell'estensione sono nascoste ai gestori di eventi di blocco per evitare deadlock. Tieni presente che per alcuni schemi supportati l'insieme di eventi disponibili potrebbe essere limitato a causa della natura del protocollo corrispondente. Ad esempio, per lo schema del file, possono essere inviati solo onBeforeRequest
, onResponseStarted
, onCompleted
e onErrorOccurred
.
A partire da Chrome 58, l'API webRequest supporta l'intercettazione della richiesta di handshake WebSocket. Poiché l'handshake viene eseguito tramite una richiesta di upgrade HTTP, il suo flusso si adatta al modello webRequest orientato a HTTP. Tieni presente che l'API non intercetta:
- Messaggi individuali inviati tramite una connessione WebSocket stabilita.
- WebSocket chiude la connessione.
I reindirizzamenti non sono supportati per le richieste WebSocket.
A partire da Chrome 72, un'estensione potrà intercettare una richiesta solo se dispone delle autorizzazioni host sia per l'URL richiesto sia per l'iniziatore della richiesta.
A partire da Chrome 96, l'API webRequest supporta l'intercettazione della richiesta di handshake WebTransport su HTTP/3. Poiché l'handshake viene eseguito tramite una richiesta HTTP CONNECT, il suo flusso si adatta al modello webRequest orientato a HTTP. Ricorda:
- Una volta stabilita la sessione, le estensioni non possono osservarla o intervenire tramite l'API webRequest.
- La modifica delle intestazioni delle richieste HTTP in
onBeforeSendHeaders
viene ignorata. - I reindirizzamenti e le autenticazioni non sono supportati in WebTransport su HTTP/3.
ID richiesta
Ogni richiesta è identificata da un ID richiesta. Questo ID è univoco all'interno di una sessione del browser e del contesto di un'estensione. Rimane costante durante il ciclo di vita di una richiesta e può essere utilizzato per abbinare gli eventi della stessa richiesta. Tieni presente che diverse richieste HTTP vengono mappate a una richiesta web in caso di reindirizzamento HTTP o autenticazione HTTP.
Registrazione dei listener di eventi
Per registrare un listener di eventi per una richiesta web, utilizzi una variante della solita funzione addListener()
. Oltre a specificare una funzione di callback, devi specificare un argomento di filtro e puoi specificare un argomento di informazioni aggiuntive facoltativo.
I tre argomenti di addListener()
dell'API di richiesta web hanno le seguenti definizioni:
var callback = function(details) {...}; var filter = {...}; var opt_extraInfoSpec = [...];
Ecco un esempio di ascolto dell'evento onBeforeRequest
:
chrome.webRequest.onBeforeRequest.addListener( callback, filter, opt_extraInfoSpec);
Ogni chiamata addListener()
accetta una funzione di callback obbligatoria come primo parametro. A questa funzione di callback viene passato un dizionario contenente informazioni sulla richiesta di URL corrente. Le informazioni in questo dizionario dipendono dal tipo di evento specifico e dal contenuto di opt_extraInfoSpec
.
Se l'array opt_extraInfoSpec
facoltativo contiene la stringa 'blocking'
(consentita solo per eventi specifici), la funzione di callback viene gestita in modo sincrono. Ciò significa che la richiesta viene bloccata finché la funzione di callback non restituisce un valore. In questo caso, il callback può restituire un webRequest.BlockingResponse
che determina l'ulteriore ciclo di vita della richiesta. A seconda del contesto, questa risposta consente di annullare o reindirizzare una richiesta (onBeforeRequest
), annullare una richiesta o modificare le intestazioni (onBeforeSendHeaders
, onHeadersReceived
) e annullare una richiesta o fornire credenziali di autenticazione (onAuthRequired
).
Se l'array facoltativo opt_extraInfoSpec
contiene invece la stringa 'asyncBlocking'
(consentita solo per onAuthRequired
), l'estensione può generare webRequest.BlockingResponse
in modo asincrono.
webRequest.RequestFilter
filter
consente di limitare le richieste per le quali vengono attivati gli eventi in varie dimensioni:
- URL
- Pattern URL come
*://www.google.com/foo*bar
. - Tipi
- Tipi di richieste come
main_frame
(un documento caricato per un frame di primo livello),sub_frame
(un documento caricato per un frame incorporato) eimage
(un'immagine su un sito web). VediwebRequest.RequestFilter
. - ID scheda
- L'identificatore di una scheda.
- ID finestra
- L'identificatore di una finestra.
A seconda del tipo di evento, puoi specificare stringhe in opt_extraInfoSpec
per richiedere ulteriori informazioni sulla richiesta. Viene utilizzato per fornire informazioni dettagliate sui dati della richiesta solo se richiesto esplicitamente.
Gestione dell'autenticazione
Per gestire le richieste di autenticazione HTTP, aggiungi l'autorizzazione "webRequestAuthProvider"
al file manifest:
{ "permissions": [ "webRequest", "webRequestAuthProvider" ] }
Tieni presente che questa autorizzazione non è richiesta per un'estensione installata con i criteri con l'autorizzazione "webRequestBlocking"
.
Per fornire le credenziali in modo sincrono:
chrome.webRequest.onAuthRequired.addListener((details) => { return { authCredentials: { username: 'guest', password: 'guest' } }; }, { urls: ['https://httpbin.org/basic-auth/guest/guest'] }, ['blocking'] );
Per fornire le credenziali in modo asincrono:
chrome.webRequest.onAuthRequired.addListener((details, callback) => { callback({ authCredentials: { username: 'guest', password: 'guest' } }); }, { urls: ['https://httpbin.org/basic-auth/guest/guest'] }, ['asyncBlocking'] );
Dettagli di implementazione
Quando sviluppi un'estensione che utilizza l'API per le richieste web, è importante comprendere diversi dettagli di implementazione:
web_accessible_resources
Quando un'estensione utilizza le API webRequest per reindirizzare una richiesta di risorse pubbliche a una risorsa non accessibile dal web, viene bloccata e genera un errore. Quanto sopra vale anche se la risorsa non accessibile dal web è di proprietà dell'estensione di reindirizzamento. Per dichiarare le risorse da utilizzare con le API declarativeWebRequest, l'array "web_accessible_resources"
deve essere dichiarato e compilato nel manifest come documentato qui.
Risoluzione dei conflitti
Nell'implementazione attuale dell'API di richiesta web, una richiesta viene considerata annullata se almeno un'estensione indica di annullarla. Se un'estensione annulla una richiesta, tutte le estensioni vengono avvisate da un evento onErrorOccurred
. Solo un'estensione può reindirizzare una richiesta o modificare un'intestazione alla volta. Se più di un'estensione tenta di modificare la richiesta, viene presa in considerazione l'estensione installata più di recente e tutte le altre vengono ignorate. Un'estensione non viene avvisata se la sua istruzione di modifica o reindirizzamento è stata ignorata.
Memorizzazione nella cache
Chrome utilizza due cache: una su disco e una in memoria molto veloce. La durata di una cache in memoria è associata alla durata di un processo di rendering, che corrisponde approssimativamente a una scheda. Le richieste a cui viene data risposta dalla cache in memoria non sono visibili all'API di richiesta web. Se un gestore delle richieste modifica il proprio comportamento (ad esempio, il comportamento in base al quale le richieste vengono bloccate), un semplice aggiornamento della pagina potrebbe non rispettare questo comportamento modificato. Per assicurarti che la modifica del comportamento venga applicata, chiama handlerBehaviorChanged()
per svuotare la cache in memoria. Ma non farlo spesso; lo svuotamento della cache è un'operazione molto costosa. Non è necessario chiamare handlerBehaviorChanged()
dopo aver registrato o annullato la registrazione di un listener di eventi.
Timestamp
La proprietà timestamp
degli eventi di richiesta web è garantita solo per essere coerente internamente. Il confronto di un evento con un altro evento fornirà l'offset corretto tra loro, ma il confronto con l'ora corrente all'interno dell'estensione (ad esempio tramite (new Date()).getTime()
) potrebbe dare risultati imprevisti.
Gestione degli errori
Se provi a registrare un evento con argomenti non validi, verrà generato un errore JavaScript e il gestore eventi non verrà registrato. Se viene generato un errore durante la gestione di un evento o se un gestore di eventi restituisce una risposta di blocco non valida, un messaggio di errore viene registrato nella console dell'estensione e il gestore viene ignorato per quella richiesta.
Esempi
L'esempio seguente illustra come bloccare tutte le richieste a www.evil.com
:
chrome.webRequest.onBeforeRequest.addListener( function(details) { return {cancel: details.url.indexOf("://www.evil.com/") != -1}; }, {urls: ["<all_urls>"]}, ["blocking"] );
Poiché questa funzione utilizza un gestore di eventi di blocco, richiede l'autorizzazione "webRequest"
e "webRequestBlocking"
nel file manifest.
Il seguente esempio raggiunge lo stesso obiettivo in modo più efficiente perché le richieste non destinate a www.evil.com
non devono essere trasmesse all'estensione:
chrome.webRequest.onBeforeRequest.addListener( function(details) { return {cancel: true}; }, {urls: ["*://www.evil.com/*"]}, ["blocking"] );
L'esempio seguente mostra come eliminare l'intestazione User-Agent da tutte le richieste:
chrome.webRequest.onBeforeSendHeaders.addListener( function(details) { for (var i = 0; i < details.requestHeaders.length; ++i) { if (details.requestHeaders[i].name === 'User-Agent') { details.requestHeaders.splice(i, 1); break; } } return {requestHeaders: details.requestHeaders}; }, {urls: ["<all_urls>"]}, ["blocking", "requestHeaders"] );
Per provare l'API chrome.webRequest
, installa l'esempio webRequest dal repository chrome-extension-samples.
Tipi
BlockingResponse
Restituisce il valore per i gestori di eventi a cui è stata applicata la specifica extraInfoSpec "blocking". Consente al gestore di eventi di modificare le richieste di rete.
Proprietà
- authCredentials
oggetto facoltativo
Utilizzato solo come risposta all'evento onAuthRequired. Se impostata, la richiesta viene effettuata utilizzando le credenziali fornite.
- password
stringa
- nome utente
stringa
-
- annulla
booleano facoltativo
Se è vero, la richiesta viene annullata. In questo modo, la richiesta non viene inviata. Può essere utilizzato come risposta agli eventi onBeforeRequest, onBeforeSendHeaders, onHeadersReceived e onAuthRequired.
- redirectUrl
stringa facoltativa
Utilizzato solo come risposta agli eventi onBeforeRequest e onHeadersReceived. Se impostata, l'invio/il completamento della richiesta originale viene impedito e la richiesta viene reindirizzata all'URL specificato. Sono consentiti i reindirizzamenti a schemi non HTTP come
data:
. I reindirizzamenti avviati da un'azione di reindirizzamento utilizzano il metodo di richiesta originale per il reindirizzamento, con un'eccezione: se il reindirizzamento viene avviato nella fase onHeadersReceived, verrà emesso utilizzando il metodo GET. I reindirizzamenti dagli URL con schemiws://
ewss://
vengono ignorati. - requestHeaders
HttpHeaders (facoltativo)
Utilizzato solo come risposta all'evento onBeforeSendHeaders. Se impostata, la richiesta viene effettuata con queste intestazioni di richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Utilizzato solo come risposta all'evento onHeadersReceived. Se impostato, si presume che il server abbia risposto con queste intestazioni di risposta. Restituisci
responseHeaders
solo se vuoi davvero modificare le intestazioni per limitare il numero di conflitti (solo un'estensione può modificareresponseHeaders
per ogni richiesta).
FormDataItem
Contiene i dati trasmessi all'interno dei dati del modulo. Per il modulo urlencoded, viene archiviato come stringa se i dati sono una stringa UTF-8 e come ArrayBuffer in caso contrario. Per i dati del modulo è ArrayBuffer. Se form-data rappresenta il caricamento del file, è una stringa con il nome del file, se fornito.
Enum
ArrayBuffer
stringa
HttpHeaders
Un array di intestazioni HTTP. Ogni intestazione è rappresentata come un dizionario contenente le chiavi name
e value
o binaryValue
.
Tipo
object[]
Proprietà
- binaryValue
number[] facoltativo
Valore dell'intestazione HTTP se non può essere rappresentato da UTF-8, memorizzato come singoli valori di byte (0-255).
- nome
stringa
Nome dell'intestazione HTTP.
- valore
stringa facoltativa
Valore dell'intestazione HTTP se può essere rappresentato da UTF-8.
IgnoredActionType
Enum
"redirect"
"request_headers"
"response_headers"
"auth_credentials"
OnAuthRequiredOptions
Enum
"responseHeaders"
Specifica che le intestazioni di risposta devono essere incluse nell'evento.
"blocking"
Specifica che la richiesta è bloccata finché la funzione di callback non restituisce un valore.
"asyncBlocking"
Specifica che la funzione di callback viene gestita in modo asincrono.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnBeforeRedirectOptions
Enum
"responseHeaders"
Specifica che le intestazioni di risposta devono essere incluse nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnBeforeRequestOptions
Enum
"blocking"
Specifica che la richiesta è bloccata finché la funzione di callback non restituisce un valore.
"requestBody"
Specifica che il corpo della richiesta deve essere incluso nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnBeforeSendHeadersOptions
Enum
"requestHeaders"
Specifica che l'intestazione della richiesta deve essere inclusa nell'evento.
"blocking"
Specifica che la richiesta è bloccata finché la funzione di callback non restituisce un valore.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnCompletedOptions
Enum
"responseHeaders"
Specifica che le intestazioni di risposta devono essere incluse nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnErrorOccurredOptions
Valore
"extraHeaders"
OnHeadersReceivedOptions
Enum
"blocking"
Specifica che la richiesta è bloccata finché la funzione di callback non restituisce un valore.
"responseHeaders"
Specifica che le intestazioni di risposta devono essere incluse nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnResponseStartedOptions
Enum
"responseHeaders"
Specifica che le intestazioni di risposta devono essere incluse nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
OnSendHeadersOptions
Enum
"requestHeaders"
Specifica che l'intestazione della richiesta deve essere inclusa nell'evento.
"extraHeaders"
Specifica che le intestazioni possono violare la condivisione delle risorse tra origini (CORS).
RequestFilter
Un oggetto che descrive i filtri da applicare agli eventi webRequest.
Proprietà
- tabId
number (facoltativo)
- tipi
ResourceType[] facoltativo
Un elenco di tipi di richieste. Le richieste che non possono corrispondere a nessuno dei tipi verranno filtrate.
- Url
string[]
Un elenco di URL o pattern URL. Le richieste che non corrispondono a nessuno degli URL verranno filtrate.
- windowId
number (facoltativo)
ResourceType
Enum
"main_frame"
Specifica la risorsa come frame principale.
"sub_frame"
Specifica la risorsa come un subframe.
"stylesheet"
Specifica la risorsa come foglio di stile.
"script"
Specifica la risorsa come script.
"image"
Specifica la risorsa come immagine.
"font"
Specifica la risorsa come carattere.
"object"
Specifica la risorsa come oggetto.
"xmlhttprequest"
Specifica la risorsa come XMLHttpRequest.
"ping"
Specifica la risorsa come ping.
"csp_report"
Specifica la risorsa come report Content Security Policy (CSP).
"media"
Specifica la risorsa come oggetto multimediale.
"websocket"
Specifica la risorsa come WebSocket.
"webbundle"
Specifica la risorsa come WebBundle.
"other"
Specifica la risorsa come un tipo non incluso nei tipi elencati.
UploadData
Contiene i dati caricati in una richiesta URL.
Proprietà
- byte
qualsiasi facoltativo
Un ArrayBuffer con una copia dei dati.
- file
stringa facoltativa
Una stringa con il percorso e il nome del file.
Proprietà
MAX_HANDLER_BEHAVIOR_CHANGED_CALLS_PER_10_MINUTES
Il numero massimo di volte in cui è possibile chiamare handlerBehaviorChanged
per intervallo sostenuto di 10 minuti. handlerBehaviorChanged
è una chiamata di funzione costosa che non deve essere chiamata spesso.
Valore
20
Metodi
handlerBehaviorChanged()
chrome.webRequest.handlerBehaviorChanged(): Promise<void>
Deve essere chiamato quando il comportamento dei gestori webRequest è cambiato per evitare una gestione errata a causa della memorizzazione nella cache. Questa chiamata di funzione è costosa. Non chiamarlo spesso.
Resi
-
Promise<void>
Chrome 116+
Eventi
onActionIgnored
chrome.webRequest.onActionIgnored.addListener(
callback: function,
)
Attivato quando la modifica proposta da un'estensione a una richiesta di rete viene ignorata. Ciò accade in caso di conflitti con altre estensioni.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- azione
L'azione proposta che è stata ignorata.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
-
-
onAuthRequired
chrome.webRequest.onAuthRequired.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnAuthRequiredOptions[],
)
Attivato quando viene ricevuto un errore di autenticazione. Il listener ha tre opzioni: può fornire le credenziali di autenticazione, può annullare la richiesta e visualizzare la pagina di errore oppure non può intraprendere alcuna azione sulla sfida. Se vengono fornite credenziali utente errate, questo metodo potrebbe essere chiamato più volte per la stessa richiesta. Tieni presente che nel parametro extraInfoSpec
deve essere specificata una sola delle modalità 'blocking'
o 'asyncBlocking'
.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object, asyncCallback?: function) => BlockingResponse | undefined
- dettagli
oggetto
- sfidante
oggetto
Il server che richiede l'autenticazione.
- host
stringa
- porta
numero
-
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- isProxy
booleano
True per Proxy-Authenticate, false per WWW-Authenticate.
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- area di autenticazione
stringa facoltativa
Il realm di autenticazione fornito dal server, se presente.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Le intestazioni della risposta HTTP ricevute insieme a questa risposta.
- schema
stringa
Lo schema di autenticazione, ad esempio Basic o Digest.
- statusCode
numero
Chrome 43 o versioni successiveCodice di stato HTTP standard restituito dal server.
- statusLine
stringa
Riga di stato HTTP della risposta o stringa "HTTP/0.9 200 OK" per le risposte HTTP/0.9 (ovvero le risposte che non hanno una riga di stato) o una stringa vuota se non sono presenti intestazioni.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
- asyncCallback
funzione facoltativa
Chrome 58+Il parametro
asyncCallback
ha il seguente aspetto:(response: BlockingResponse) => void
- risposta
-
- returns
BlockingResponse | undefined
Se "blocking" è specificato nel parametro "extraInfoSpec", il listener di eventi deve restituire un oggetto di questo tipo.
-
- filtro
- extraInfoSpec
OnAuthRequiredOptions[] facoltativo
onBeforeRedirect
chrome.webRequest.onBeforeRedirect.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeRedirectOptions[],
)
Attivato quando sta per verificarsi un reindirizzamento avviato dal server.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- fromCache
booleano
Indica se questa risposta è stata recuperata dalla cache su disco.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- ip
stringa facoltativa
L'indirizzo IP del server a cui è stata effettivamente inviata la richiesta. Tieni presente che potrebbe trattarsi di un indirizzo IPv6 letterale.
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- redirectUrl
stringa
Il nuovo URL.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Le intestazioni della risposta HTTP ricevute insieme a questo reindirizzamento.
- statusCode
numero
Codice di stato HTTP standard restituito dal server.
- statusLine
stringa
Riga di stato HTTP della risposta o stringa "HTTP/0.9 200 OK" per le risposte HTTP/0.9 (ovvero le risposte che non hanno una riga di stato) o una stringa vuota se non sono presenti intestazioni.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
-
- filtro
- extraInfoSpec
OnBeforeRedirectOptions[] facoltativo
onBeforeRequest
chrome.webRequest.onBeforeRequest.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeRequestOptions[],
)
Attivato quando sta per verificarsi una richiesta.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => BlockingResponse | undefined
- dettagli
oggetto
- documentId
stringa facoltativa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycle
extensionTypes.DocumentLifecycle facoltativo
Chrome 106+Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameType
extensionTypes.FrameType facoltativo
Chrome 106+Il tipo di frame in cui si è verificata la richiesta.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestBody
oggetto facoltativo
Contiene i dati del corpo della richiesta HTTP. Fornito solo se extraInfoSpec contiene "requestBody".
- errore
stringa facoltativa
Errori durante l'ottenimento dei dati del corpo della richiesta.
- formData
oggetto facoltativo
Se il metodo della richiesta è POST e il corpo è una sequenza di coppie chiave-valore codificate in UTF8, codificate come multipart/form-data o application/x-www-form-urlencoded, questo dizionario è presente e per ogni chiave contiene l'elenco di tutti i valori per quella chiave. Se i dati sono di un altro tipo di media o se sono danneggiati, il dizionario non è presente. Un valore di esempio di questo dizionario è {'key': ['value1', 'value2']}.
- raw
UploadData[] facoltativo
Se il metodo di richiesta è PUT o POST e il corpo non è già analizzato in formData, gli elementi del corpo della richiesta non analizzati sono contenuti in questo array.
-
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
- returns
BlockingResponse | undefined
Se "blocking" è specificato nel parametro "extraInfoSpec", il listener di eventi deve restituire un oggetto di questo tipo.
-
- filtro
- extraInfoSpec
OnBeforeRequestOptions[] facoltativo
onBeforeSendHeaders
chrome.webRequest.onBeforeSendHeaders.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnBeforeSendHeadersOptions[],
)
Attivato prima dell'invio di una richiesta HTTP, una volta disponibili le intestazioni della richiesta. Ciò può verificarsi dopo che è stata stabilita una connessione TCP al server, ma prima che vengano inviati dati HTTP.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => BlockingResponse | undefined
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestHeaders
HttpHeaders (facoltativo)
Le intestazioni delle richieste HTTP che verranno inviate con questa richiesta.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
- returns
BlockingResponse | undefined
Se "blocking" è specificato nel parametro "extraInfoSpec", il listener di eventi deve restituire un oggetto di questo tipo.
-
- filtro
- extraInfoSpec
OnBeforeSendHeadersOptions[] facoltativo
onCompleted
chrome.webRequest.onCompleted.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnCompletedOptions[],
)
Attivato al termine di una richiesta.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- fromCache
booleano
Indica se questa risposta è stata recuperata dalla cache su disco.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- ip
stringa facoltativa
L'indirizzo IP del server a cui è stata effettivamente inviata la richiesta. Tieni presente che potrebbe trattarsi di un indirizzo IPv6 letterale.
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Le intestazioni della risposta HTTP ricevute insieme a questa risposta.
- statusCode
numero
Codice di stato HTTP standard restituito dal server.
- statusLine
stringa
Riga di stato HTTP della risposta o stringa "HTTP/0.9 200 OK" per le risposte HTTP/0.9 (ovvero le risposte che non hanno una riga di stato) o una stringa vuota se non sono presenti intestazioni.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
-
- filtro
- extraInfoSpec
OnCompletedOptions[] facoltativo
onErrorOccurred
chrome.webRequest.onErrorOccurred.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnErrorOccurredOptions[],
)
Attivato quando si verifica un errore.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta. Questo valore non è presente se la richiesta è una navigazione di un frame.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- errore
stringa
La descrizione dell'errore. Non è garantito che questa stringa rimanga compatibile con le versioni precedenti tra le release. Non devi analizzare e agire in base ai suoi contenuti.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- fromCache
booleano
Indica se questa risposta è stata recuperata dalla cache su disco.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- ip
stringa facoltativa
L'indirizzo IP del server a cui è stata effettivamente inviata la richiesta. Tieni presente che potrebbe trattarsi di un indirizzo IPv6 letterale.
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
-
- filtro
- extraInfoSpec
OnErrorOccurredOptions[] facoltativo
onHeadersReceived
chrome.webRequest.onHeadersReceived.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnHeadersReceivedOptions[],
)
Attivato quando sono state ricevute le intestazioni della risposta HTTP di una richiesta.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => BlockingResponse | undefined
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Le intestazioni di risposta HTTP ricevute con questa risposta.
- statusCode
numero
Chrome 43 o versioni successiveCodice di stato HTTP standard restituito dal server.
- statusLine
stringa
Riga di stato HTTP della risposta o stringa "HTTP/0.9 200 OK" per le risposte HTTP/0.9 (ovvero le risposte che non hanno una riga di stato).
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
- returns
BlockingResponse | undefined
Se "blocking" è specificato nel parametro "extraInfoSpec", il listener di eventi deve restituire un oggetto di questo tipo.
-
- filtro
- extraInfoSpec
OnHeadersReceivedOptions[] facoltativo
onResponseStarted
chrome.webRequest.onResponseStarted.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnResponseStartedOptions[],
)
Attivato quando viene ricevuto il primo byte del corpo della risposta. Per le richieste HTTP, ciò significa che sono disponibili la riga di stato e le intestazioni della risposta.
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- fromCache
booleano
Indica se questa risposta è stata recuperata dalla cache su disco.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- ip
stringa facoltativa
L'indirizzo IP del server a cui è stata effettivamente inviata la richiesta. Tieni presente che potrebbe trattarsi di un indirizzo IPv6 letterale.
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- responseHeaders
HttpHeaders (facoltativo)
Le intestazioni della risposta HTTP ricevute insieme a questa risposta.
- statusCode
numero
Codice di stato HTTP standard restituito dal server.
- statusLine
stringa
Riga di stato HTTP della risposta o stringa "HTTP/0.9 200 OK" per le risposte HTTP/0.9 (ovvero le risposte che non hanno una riga di stato) o una stringa vuota se non sono presenti intestazioni.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
-
- filtro
- extraInfoSpec
OnResponseStartedOptions[] facoltativo
onSendHeaders
chrome.webRequest.onSendHeaders.addListener(
callback: function,
filter: RequestFilter,
extraInfoSpec?: OnSendHeadersOptions[],
)
Attivato appena prima dell'invio di una richiesta al server (le modifiche ai callback onBeforeSendHeaders precedenti sono visibili al momento dell'attivazione di onSendHeaders).
Parametri
- callback
funzione
Il parametro
callback
ha il seguente aspetto:(details: object) => void
- dettagli
oggetto
- documentId
stringa
Chrome 106+L'UUID del documento che effettua la richiesta.
- documentLifecycleChrome 106+
Il ciclo di vita in cui si trova il documento.
- frameId
numero
Il valore 0 indica che la richiesta viene eseguita nel frame principale; un valore positivo indica l'ID di un subframe in cui viene eseguita la richiesta. Se il documento di un (sotto)frame viene caricato (
type
èmain_frame
osub_frame
),frameId
indica l'ID di questo frame, non l'ID del frame esterno. Gli ID frame sono univoci all'interno di una scheda. - frameTypeChrome 106+
Il tipo di frame in cui si è verificata la richiesta.
- iniziatore
stringa facoltativa
Chrome 63+L'origine da cui è stata avviata la richiesta. Questo valore non cambia con i reindirizzamenti. Se si tratta di un'origine opaca, verrà utilizzata la stringa "null".
- method
stringa
Metodo HTTP standard.
- parentDocumentId
stringa facoltativa
Chrome 106+L'UUID del documento principale proprietario di questo frame. Questo valore non viene impostato se non è presente un genitore.
- parentFrameId
numero
ID del frame che contiene il frame che ha inviato la richiesta. Imposta su -1 se non esiste un frame principale.
- requestHeaders
HttpHeaders (facoltativo)
Le intestazioni delle richieste HTTP inviate con questa richiesta.
- requestId
stringa
L'ID della richiesta. Gli ID richiesta sono univoci all'interno di una sessione del browser. Di conseguenza, potrebbero essere utilizzati per mettere in relazione diversi eventi della stessa richiesta.
- tabId
numero
L'ID della scheda in cui viene eseguita la richiesta. Imposta il valore su -1 se la richiesta non è correlata a una scheda.
- timeStamp
numero
Il momento in cui viene attivato questo segnale, in millisecondi dall'epoca.
- tipo
Come verrà utilizzata la risorsa richiesta.
- url
stringa
-
-
- filtro
- extraInfoSpec
OnSendHeadersOptions[] facoltativo