2016-11-10 20:25:26 +00:00
|
|
|
## Class: ClientRequest
|
|
|
|
|
|
|
|
> Make HTTP/HTTPS requests.
|
|
|
|
|
2016-11-23 19:20:56 +00:00
|
|
|
Process: [Main](../glossary.md#main-process)
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
`ClientRequest` implements the [Writable Stream](https://nodejs.org/api/stream.html#stream_writable_streams)
|
2019-07-22 15:20:43 +00:00
|
|
|
interface and is therefore an [EventEmitter][event-emitter].
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
### `new ClientRequest(options)`
|
|
|
|
|
|
|
|
* `options` (Object | String) - If `options` is a String, it is interpreted as
|
|
|
|
the request URL. If it is an object, it is expected to fully specify an HTTP request via the
|
|
|
|
following properties:
|
|
|
|
* `method` String (optional) - The HTTP request method. Defaults to the GET
|
2020-09-29 16:03:33 +00:00
|
|
|
method.
|
2016-11-10 20:25:26 +00:00
|
|
|
* `url` String (optional) - The request URL. Must be provided in the absolute
|
2020-09-29 16:03:33 +00:00
|
|
|
form with the protocol scheme specified as http or https.
|
2019-08-05 17:45:58 +00:00
|
|
|
* `session` Session (optional) - The [`Session`](session.md) instance with
|
2020-09-29 16:03:33 +00:00
|
|
|
which the request is associated.
|
2016-11-10 20:25:26 +00:00
|
|
|
* `partition` String (optional) - The name of the [`partition`](session.md)
|
2020-09-29 16:03:33 +00:00
|
|
|
with which the request is associated. Defaults to the empty string. The
|
|
|
|
`session` option supersedes `partition`. Thus if a `session` is explicitly
|
|
|
|
specified, `partition` is ignored.
|
|
|
|
* `credentials` String (optional) - Can be `include` or `omit`. Whether to
|
|
|
|
send [credentials](https://fetch.spec.whatwg.org/#credentials) with this
|
|
|
|
request. If set to `include`, credentials from the session associated with
|
|
|
|
the request will be used. If set to `omit`, credentials will not be sent
|
|
|
|
with the request (and the `'login'` event will not be triggered in the
|
|
|
|
event of a 401). This matches the behavior of the
|
|
|
|
[fetch](https://fetch.spec.whatwg.org/#concept-request-credentials-mode)
|
|
|
|
option of the same name. If this option is not specified, authentication
|
|
|
|
data from the session will be sent, and cookies will not be sent (unless
|
|
|
|
`useSessionCookies` is set).
|
2020-03-20 22:56:02 +00:00
|
|
|
* `useSessionCookies` Boolean (optional) - Whether to send cookies with this
|
2020-09-29 16:03:33 +00:00
|
|
|
request from the provided session. If `credentials` is specified, this
|
|
|
|
option has no effect. Default is `false`.
|
|
|
|
* `protocol` String (optional) - Can be `http:` or `https:`. The protocol
|
|
|
|
scheme in the form 'scheme:'. Defaults to 'http:'.
|
2016-11-10 20:25:26 +00:00
|
|
|
* `host` String (optional) - The server host provided as a concatenation of
|
2020-09-29 16:03:33 +00:00
|
|
|
the hostname and the port number 'hostname:port'.
|
2016-11-10 20:25:26 +00:00
|
|
|
* `hostname` String (optional) - The server host name.
|
|
|
|
* `port` Integer (optional) - The server's listening port number.
|
|
|
|
* `path` String (optional) - The path part of the request URL.
|
2020-09-29 16:03:33 +00:00
|
|
|
* `redirect` String (optional) - Can be `follow`, `error` or `manual`. The
|
|
|
|
redirect mode for this request. When mode is `error`, any redirection will
|
|
|
|
be aborted. When mode is `manual` the redirection will be cancelled unless
|
|
|
|
[`request.followRedirect`](#requestfollowredirect) is invoked synchronously
|
|
|
|
during the [`redirect`](#event-redirect) event. Defaults to `follow`.
|
2020-11-17 22:25:41 +00:00
|
|
|
* `origin` String (optional) - The origin URL of the request.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
`options` properties such as `protocol`, `host`, `hostname`, `port` and `path`
|
|
|
|
strictly follow the Node.js model as described in the
|
|
|
|
[URL](https://nodejs.org/api/url.html) module.
|
|
|
|
|
|
|
|
For instance, we could have created the same request to 'github.com' as follows:
|
|
|
|
|
|
|
|
```JavaScript
|
|
|
|
const request = net.request({
|
|
|
|
method: 'GET',
|
|
|
|
protocol: 'https:',
|
|
|
|
hostname: 'github.com',
|
|
|
|
port: 443,
|
|
|
|
path: '/'
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
### Instance Events
|
|
|
|
|
|
|
|
#### Event: 'response'
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
2021-06-03 05:54:33 +00:00
|
|
|
* `response` [IncomingMessage](incoming-message.md) - An object representing the HTTP response message.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
#### Event: 'login'
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
* `authInfo` Object
|
|
|
|
* `isProxy` Boolean
|
|
|
|
* `scheme` String
|
|
|
|
* `host` String
|
|
|
|
* `port` Integer
|
|
|
|
* `realm` String
|
|
|
|
* `callback` Function
|
2019-11-14 18:01:18 +00:00
|
|
|
* `username` String (optional)
|
|
|
|
* `password` String (optional)
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
Emitted when an authenticating proxy is asking for user credentials.
|
|
|
|
|
|
|
|
The `callback` function is expected to be called back with user credentials:
|
|
|
|
|
|
|
|
* `username` String
|
|
|
|
* `password` String
|
|
|
|
|
|
|
|
```JavaScript
|
|
|
|
request.on('login', (authInfo, callback) => {
|
|
|
|
callback('username', 'password')
|
|
|
|
})
|
|
|
|
```
|
2020-11-05 22:12:43 +00:00
|
|
|
|
2016-11-10 20:25:26 +00:00
|
|
|
Providing empty credentials will cancel the request and report an authentication
|
|
|
|
error on the response object:
|
|
|
|
|
|
|
|
```JavaScript
|
|
|
|
request.on('response', (response) => {
|
|
|
|
console.log(`STATUS: ${response.statusCode}`);
|
|
|
|
response.on('error', (error) => {
|
|
|
|
console.log(`ERROR: ${JSON.stringify(error)}`)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
request.on('login', (authInfo, callback) => {
|
|
|
|
callback()
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Event: 'finish'
|
|
|
|
|
|
|
|
Emitted just after the last chunk of the `request`'s data has been written into
|
|
|
|
the `request` object.
|
|
|
|
|
|
|
|
#### Event: 'abort'
|
|
|
|
|
|
|
|
Emitted when the `request` is aborted. The `abort` event will not be fired if
|
|
|
|
the `request` is already closed.
|
|
|
|
|
|
|
|
#### Event: 'error'
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
* `error` Error - an error object providing some information about the failure.
|
|
|
|
|
|
|
|
Emitted when the `net` module fails to issue a network request. Typically when
|
|
|
|
the `request` object emits an `error` event, a `close` event will subsequently
|
|
|
|
follow and no response object will be provided.
|
|
|
|
|
|
|
|
#### Event: 'close'
|
|
|
|
|
|
|
|
Emitted as the last event in the HTTP request-response transaction. The `close`
|
|
|
|
event indicates that no more events will be emitted on either the `request` or
|
|
|
|
`response` objects.
|
|
|
|
|
2017-03-25 07:07:34 +00:00
|
|
|
#### Event: 'redirect'
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
* `statusCode` Integer
|
|
|
|
* `method` String
|
|
|
|
* `redirectUrl` String
|
2019-08-05 17:45:58 +00:00
|
|
|
* `responseHeaders` Record<String, String[]>
|
2017-03-25 07:07:34 +00:00
|
|
|
|
2019-11-27 01:01:13 +00:00
|
|
|
Emitted when the server returns a redirect response (e.g. 301 Moved
|
|
|
|
Permanently). Calling [`request.followRedirect`](#requestfollowredirect) will
|
|
|
|
continue with the redirection. If this event is handled,
|
|
|
|
[`request.followRedirect`](#requestfollowredirect) must be called
|
|
|
|
**synchronously**, otherwise the request will be cancelled.
|
2017-03-25 07:07:34 +00:00
|
|
|
|
2016-11-10 20:25:26 +00:00
|
|
|
### Instance Properties
|
|
|
|
|
|
|
|
#### `request.chunkedEncoding`
|
|
|
|
|
2017-07-24 08:29:03 +00:00
|
|
|
A `Boolean` specifying whether the request will use HTTP chunked transfer encoding
|
2016-11-10 20:25:26 +00:00
|
|
|
or not. Defaults to false. The property is readable and writable, however it can
|
|
|
|
be set only before the first write operation as the HTTP headers are not yet put
|
|
|
|
on the wire. Trying to set the `chunkedEncoding` property after the first write
|
|
|
|
will throw an error.
|
|
|
|
|
|
|
|
Using chunked encoding is strongly recommended if you need to send a large
|
|
|
|
request body as data will be streamed in small chunks instead of being
|
|
|
|
internally buffered inside Electron process memory.
|
|
|
|
|
|
|
|
### Instance Methods
|
|
|
|
|
|
|
|
#### `request.setHeader(name, value)`
|
|
|
|
|
|
|
|
* `name` String - An extra HTTP header name.
|
2019-08-05 17:45:58 +00:00
|
|
|
* `value` String - An extra HTTP header value.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
2019-06-21 21:19:21 +00:00
|
|
|
Adds an extra HTTP header. The header name will be issued as-is without
|
2016-11-10 20:25:26 +00:00
|
|
|
lowercasing. It can be called only before first write. Calling this method after
|
2017-03-30 16:24:40 +00:00
|
|
|
the first write will throw an error. If the passed value is not a `String`, its
|
|
|
|
`toString()` method will be called to obtain the final value.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
2020-08-25 11:29:58 +00:00
|
|
|
Certain headers are restricted from being set by apps. These headers are
|
|
|
|
listed below. More information on restricted headers can be found in
|
|
|
|
[Chromium's header utils](https://source.chromium.org/chromium/chromium/src/+/master:services/network/public/cpp/header_util.cc;drc=1562cab3f1eda927938f8f4a5a91991fefde66d3;bpv=1;bpt=1;l=22).
|
|
|
|
|
|
|
|
* `Content-Length`
|
|
|
|
* `Host`
|
|
|
|
* `Trailer` or `Te`
|
|
|
|
* `Upgrade`
|
|
|
|
* `Cookie2`
|
|
|
|
* `Keep-Alive`
|
|
|
|
* `Transfer-Encoding`
|
|
|
|
|
|
|
|
Additionally, setting the `Connection` header to the value `upgrade` is also disallowed.
|
|
|
|
|
2016-11-10 20:25:26 +00:00
|
|
|
#### `request.getHeader(name)`
|
|
|
|
|
|
|
|
* `name` String - Specify an extra header name.
|
|
|
|
|
2019-08-05 17:45:58 +00:00
|
|
|
Returns `String` - The value of a previously set extra header name.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
#### `request.removeHeader(name)`
|
|
|
|
|
|
|
|
* `name` String - Specify an extra header name.
|
|
|
|
|
|
|
|
Removes a previously set extra header name. This method can be called only
|
|
|
|
before first write. Trying to call it after the first write will throw an error.
|
|
|
|
|
|
|
|
#### `request.write(chunk[, encoding][, callback])`
|
|
|
|
|
|
|
|
* `chunk` (String | Buffer) - A chunk of the request body's data. If it is a
|
|
|
|
string, it is converted into a Buffer using the specified encoding.
|
|
|
|
* `encoding` String (optional) - Used to convert string chunks into Buffer
|
|
|
|
objects. Defaults to 'utf-8'.
|
2017-07-24 08:29:03 +00:00
|
|
|
* `callback` Function (optional) - Called after the write operation ends.
|
2016-11-10 20:25:26 +00:00
|
|
|
|
|
|
|
`callback` is essentially a dummy function introduced in the purpose of keeping
|
|
|
|
similarity with the Node.js API. It is called asynchronously in the next tick
|
|
|
|
after `chunk` content have been delivered to the Chromium networking layer.
|
|
|
|
Contrary to the Node.js implementation, it is not guaranteed that `chunk`
|
|
|
|
content have been flushed on the wire before `callback` is called.
|
|
|
|
|
|
|
|
Adds a chunk of data to the request body. The first write operation may cause
|
|
|
|
the request headers to be issued on the wire. After the first write operation,
|
|
|
|
it is not allowed to add or remove a custom header.
|
|
|
|
|
|
|
|
#### `request.end([chunk][, encoding][, callback])`
|
|
|
|
|
|
|
|
* `chunk` (String | Buffer) (optional)
|
|
|
|
* `encoding` String (optional)
|
|
|
|
* `callback` Function (optional)
|
|
|
|
|
|
|
|
Sends the last chunk of the request data. Subsequent write or end operations
|
|
|
|
will not be allowed. The `finish` event is emitted just after the end operation.
|
|
|
|
|
|
|
|
#### `request.abort()`
|
|
|
|
|
|
|
|
Cancels an ongoing HTTP transaction. If the request has already emitted the
|
|
|
|
`close` event, the abort operation will have no effect. Otherwise an ongoing
|
|
|
|
event will emit `abort` and `close` events. Additionally, if there is an ongoing
|
|
|
|
response object,it will emit the `aborted` event.
|
2017-03-25 07:07:34 +00:00
|
|
|
|
|
|
|
#### `request.followRedirect()`
|
|
|
|
|
2019-11-27 01:01:13 +00:00
|
|
|
Continues any pending redirection. Can only be called during a `'redirect'`
|
|
|
|
event.
|
2018-07-27 14:15:48 +00:00
|
|
|
|
|
|
|
#### `request.getUploadProgress()`
|
|
|
|
|
|
|
|
Returns `Object`:
|
|
|
|
|
|
|
|
* `active` Boolean - Whether the request is currently active. If this is false
|
|
|
|
no other properties will be set
|
|
|
|
* `started` Boolean - Whether the upload has started. If this is false both
|
|
|
|
`current` and `total` will be set to 0.
|
|
|
|
* `current` Integer - The number of bytes that have been uploaded so far
|
|
|
|
* `total` Integer - The number of bytes that will be uploaded this request
|
|
|
|
|
|
|
|
You can use this method in conjunction with `POST` requests to get the progress
|
|
|
|
of a file upload or other data transfer.
|
2019-07-22 15:20:43 +00:00
|
|
|
|
|
|
|
[event-emitter]: https://nodejs.org/api/events.html#events_class_eventemitter
|