2016-11-10 20:25:26 +00:00
|
|
|
## Class: WebRequest
|
|
|
|
|
|
|
|
> Intercept and modify the contents of a request at various stages of its lifetime.
|
|
|
|
|
2021-06-15 20:50:31 +00:00
|
|
|
Process: [Main](../glossary.md#main-process)<br />
|
|
|
|
_This class is not exported from the `'electron'` module. It is only available as a return value of other methods in the Electron API._
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
Instances of the `WebRequest` class are accessed by using the `webRequest`
|
|
|
|
property of a `Session`.
|
|
|
|
|
|
|
|
The methods of `WebRequest` accept an optional `filter` and a `listener`. The
|
|
|
|
`listener` will be called with `listener(details)` when the API's event has
|
2018-07-30 01:38:59 +00:00
|
|
|
happened. The `details` object describes the request.
|
|
|
|
|
|
|
|
⚠️ Only the last attached `listener` will be used. Passing `null` as `listener` will unsubscribe from the event.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `filter` object has a `urls` property which is an Array of URL
|
|
|
|
patterns that will be used to filter out the requests that do not match the URL
|
|
|
|
patterns. If the `filter` is omitted then all requests will be matched.
|
|
|
|
|
|
|
|
For certain events the `listener` is passed with a `callback`, which should be
|
|
|
|
called with a `response` object when `listener` has done its work.
|
|
|
|
|
|
|
|
An example of adding `User-Agent` header for requests:
|
|
|
|
|
2023-11-21 07:50:08 +00:00
|
|
|
```js
|
2018-09-13 16:10:51 +00:00
|
|
|
const { session } = require('electron')
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
// Modify the user agent for all requests to the following urls.
|
|
|
|
const filter = {
|
2022-10-27 07:18:07 +00:00
|
|
|
urls: ['https://*.github.com/*', '*://electron.github.io/*']
|
2016-11-10 20:25:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
session.defaultSession.webRequest.onBeforeSendHeaders(filter, (details, callback) => {
|
|
|
|
details.requestHeaders['User-Agent'] = 'MyAgent'
|
2019-01-25 14:41:21 +00:00
|
|
|
callback({ requestHeaders: details.requestHeaders })
|
2016-11-10 20:25:26 +00:00
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
### Instance Methods
|
|
|
|
|
|
|
|
The following methods are available on instances of `WebRequest`:
|
|
|
|
|
|
|
|
#### `webRequest.onBeforeRequest([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
|
|
|
* `uploadData` [UploadData[]](structures/upload-data.md)
|
|
|
|
* `callback` Function
|
|
|
|
* `response` Object
|
2021-11-16 04:13:18 +00:00
|
|
|
* `cancel` boolean (optional)
|
|
|
|
* `redirectURL` string (optional) - The original request is prevented from
|
2016-11-10 20:25:26 +00:00
|
|
|
being sent or completed and is instead redirected to the given URL.
|
|
|
|
|
|
|
|
The `listener` will be called with `listener(details, callback)` when a request
|
|
|
|
is about to occur.
|
|
|
|
|
|
|
|
The `uploadData` is an array of `UploadData` objects.
|
|
|
|
|
|
|
|
The `callback` has to be called with an `response` object.
|
|
|
|
|
2019-07-25 17:20:02 +00:00
|
|
|
Some examples of valid `urls`:
|
|
|
|
|
|
|
|
```js
|
|
|
|
'http://foo:1234/'
|
|
|
|
'http://foo.com/'
|
|
|
|
'http://foo:1234/bar'
|
|
|
|
'*://*/*'
|
|
|
|
'*://example.com/*'
|
|
|
|
'*://example.com/foo/*'
|
|
|
|
'http://*.foo:1234/'
|
|
|
|
'file://foo:1234/bar'
|
|
|
|
'http://foo:*/'
|
|
|
|
'*://www.foo.com/'
|
|
|
|
```
|
|
|
|
|
2016-11-10 20:25:26 +00:00
|
|
|
#### `webRequest.onBeforeSendHeaders([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2019-01-22 16:46:40 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2019-01-22 16:46:40 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2019-01-22 16:46:40 +00:00
|
|
|
* `timestamp` Double
|
2022-01-26 16:41:54 +00:00
|
|
|
* `uploadData` [UploadData[]](structures/upload-data.md) (optional)
|
2024-03-26 11:28:47 +00:00
|
|
|
* `requestHeaders` Record\<string, string\>
|
2019-01-22 16:46:40 +00:00
|
|
|
* `callback` Function
|
2019-08-28 20:56:15 +00:00
|
|
|
* `beforeSendResponse` Object
|
2021-11-16 04:13:18 +00:00
|
|
|
* `cancel` boolean (optional)
|
2024-03-26 11:28:47 +00:00
|
|
|
* `requestHeaders` Record\<string, string | string[]\> (optional) - When provided, request will be made
|
2019-01-22 16:46:40 +00:00
|
|
|
with these headers.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details, callback)` before sending
|
|
|
|
an HTTP request, once the request headers are available. This may occur after a
|
|
|
|
TCP connection is made to the server, but before any http data is sent.
|
|
|
|
|
2019-08-28 20:56:15 +00:00
|
|
|
The `callback` has to be called with a `response` object.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
#### `webRequest.onSendHeaders([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
2024-03-26 11:28:47 +00:00
|
|
|
* `requestHeaders` Record\<string, string\>
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details)` just before a request is
|
|
|
|
going to be sent to the server, modifications of previous `onBeforeSendHeaders`
|
|
|
|
response are visible by the time this listener is fired.
|
|
|
|
|
|
|
|
#### `webRequest.onHeadersReceived([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2019-01-22 16:46:40 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2019-01-22 16:46:40 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2019-01-22 16:46:40 +00:00
|
|
|
* `timestamp` Double
|
2021-11-16 04:13:18 +00:00
|
|
|
* `statusLine` string
|
2019-01-22 16:46:40 +00:00
|
|
|
* `statusCode` Integer
|
2024-03-26 11:28:47 +00:00
|
|
|
* `responseHeaders` Record\<string, string[]\> (optional)
|
2019-01-22 16:46:40 +00:00
|
|
|
* `callback` Function
|
2019-08-28 20:56:15 +00:00
|
|
|
* `headersReceivedResponse` Object
|
2021-11-16 04:13:18 +00:00
|
|
|
* `cancel` boolean (optional)
|
2024-03-26 11:28:47 +00:00
|
|
|
* `responseHeaders` Record\<string, string | string[]\> (optional) - When provided, the server is assumed
|
2019-01-22 16:46:40 +00:00
|
|
|
to have responded with these headers.
|
2021-11-16 04:13:18 +00:00
|
|
|
* `statusLine` string (optional) - Should be provided when overriding
|
2019-01-22 16:46:40 +00:00
|
|
|
`responseHeaders` to change header status otherwise original response
|
|
|
|
header's status will be used.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details, callback)` when HTTP
|
|
|
|
response headers of a request have been received.
|
|
|
|
|
2019-08-28 20:56:15 +00:00
|
|
|
The `callback` has to be called with a `response` object.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
#### `webRequest.onResponseStarted([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
2024-03-26 11:28:47 +00:00
|
|
|
* `responseHeaders` Record\<string, string[]\> (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `fromCache` boolean - Indicates whether the response was fetched from disk
|
2016-11-10 20:25:26 +00:00
|
|
|
cache.
|
|
|
|
* `statusCode` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `statusLine` string
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details)` when first byte of the
|
|
|
|
response body is received. For HTTP requests, this means that the status line
|
|
|
|
and response headers are available.
|
|
|
|
|
|
|
|
#### `webRequest.onBeforeRedirect([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
2017-09-13 14:09:21 +00:00
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
2021-11-16 04:13:18 +00:00
|
|
|
* `redirectURL` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `statusCode` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `statusLine` string
|
|
|
|
* `ip` string (optional) - The server IP address that the request was
|
2016-11-10 20:25:26 +00:00
|
|
|
actually sent to.
|
2021-11-16 04:13:18 +00:00
|
|
|
* `fromCache` boolean
|
2024-03-26 11:28:47 +00:00
|
|
|
* `responseHeaders` Record\<string, string[]\> (optional)
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details)` when a server initiated
|
|
|
|
redirect is about to occur.
|
|
|
|
|
|
|
|
#### `webRequest.onCompleted([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
2024-03-26 11:28:47 +00:00
|
|
|
* `responseHeaders` Record\<string, string[]\> (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `fromCache` boolean
|
2016-11-10 20:25:26 +00:00
|
|
|
* `statusCode` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `statusLine` string
|
|
|
|
* `error` string
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details)` when a request is
|
|
|
|
completed.
|
|
|
|
|
|
|
|
#### `webRequest.onErrorOccurred([filter, ]listener)`
|
|
|
|
|
2021-07-08 07:20:08 +00:00
|
|
|
* `filter` [WebRequestFilter](structures/web-request-filter.md) (optional)
|
2019-02-26 02:13:00 +00:00
|
|
|
* `listener` Function | null
|
2016-11-10 20:25:26 +00:00
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
2021-11-16 04:13:18 +00:00
|
|
|
* `url` string
|
|
|
|
* `method` string
|
2017-09-13 14:09:21 +00:00
|
|
|
* `webContentsId` Integer (optional)
|
2021-01-11 03:20:43 +00:00
|
|
|
* `webContents` WebContents (optional)
|
|
|
|
* `frame` WebFrameMain (optional)
|
2021-11-16 04:13:18 +00:00
|
|
|
* `resourceType` string - Can be `mainFrame`, `subFrame`, `stylesheet`, `script`, `image`, `font`, `object`, `xhr`, `ping`, `cspReport`, `media`, `webSocket` or `other`.
|
|
|
|
* `referrer` string
|
2016-11-10 20:25:26 +00:00
|
|
|
* `timestamp` Double
|
2021-11-16 04:13:18 +00:00
|
|
|
* `fromCache` boolean
|
|
|
|
* `error` string - The error description.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
The `listener` will be called with `listener(details)` when an error occurs.
|