net
Émet des requêtes HTTP/HTTPS à l'aide de la bibliothèque réseau native de Chromium
Processus : Main
Le module net
est une API côté client pour émettre des requêtes HTTP(S). Il est semblable aux modules HTTP et HTTPS de Node.js, mais utilise la bibliothèque réseau native de Chromium au lieu de l'implémentation de Node.js, offrant ainsi un meilleur support pour les proxy web. Il prend également en charge la vérification de l'état du réseau.
Voici une liste non exhaustive de pourquoi vous devriez utiliser le module net
plutôt que les modules natifs de Node.js :
- Gestion automatique de la configuration de proxy système, support du protocole wpad et les fichiers de configuration de proxy pac.
- Tunnel automatique des requêtes HTTPS.
- Prise en charge de l'authentification proxy en utilisant basic, digest, NTLM, Kerberos ou en négociant des schémas d'authentification.
- Prise en charge des proxy de surveillance du trafic: Proxy de type Fiddler utilisés pour le contrôle et la surveillance des accès.
Les composants de l'API (y compris les classes, méthodes, propriétés et noms d'événements) sont similaires à ceux utilisés dans Node.js.
Exemple d'utilisation :
const { app } = require('electron')
app.whenReady().then(() => {
const { net } = require('electron')
const request = net.request('https://github.com')
request.on('response', (response) => {
console.log(`STATUS: ${response.statusCode}`)
console.log(`HEADERS: ${JSON.stringify(response.headers)}`)
response.on('data', (chunk) => {
console.log(`BODY: ${chunk}`)
})
response.on('end', () => {
console.log('No more data in response.')
})
})
request.end()
})
L'API net
ne peut être utilisée qu'après que l'application ait émit un événement ready
. Toute tentative d'utilisation du module avant l'événement ready
déclenchera une erreur.
Méthodes
Le module net
dispose des méthodes suivantes :
net.request(options)
Retourne ClientRequest
Créer une instance de ClientRequest
avec les options
founies qui sont directement transmis au constructor de ClientRequest
. La méthode net.request
doit être utilisée pour émettre des requêtes HTTP sécurisés et non sécurisés selon le schéma de protocole spécifié dans l'objet options
.
net.isOnline()
Retourne boolean
- Indique si uneconnexion Internet existe actuellement.
Une valeur de retour de false
indique que l'utilisateur ne pourra pas se connecter à des sites distants. Cependant, une valeur de retour à true
donne une information incertaine car même si un lien est en ligne, rien n'indique qu'une tentative de connexion à un site distant particulier soit réussie.
net.resolveHost(host, [options])
host
string - Nom d'hôte à résoudre.
Retourne Promise<ResolvedHost> - qui se résout avec les adresses IP trouvées pour le host
.
Cette méthode va résoudre les hôtes de la session par défaut . Pour résoudre un hôte d'une autre session, vous devrez utiliser ses.resolveHost().
Propriétés
net.online
Lecture seule
Propriété de type boolean
. Indique s'il y a actuellement une connexion Internet.
Une valeur de retour de false
indique que l'utilisateur ne pourra pas se connecter à des sites distants. Cependant, une valeur de retour à true
donne une information incertaine car même si un lien est en ligne, rien n'indique qu'une tentative de connexion à un site distant particulier soit réussie.