So stellen Sie HTTP-Anfragen in Node.js mit Node-Fetch

So Stellen Sie Http Anfragen In Node Js Mit Node Fetch



Die HTTP-Anfragen sind von entscheidender Bedeutung und dienen dazu, global Informationen von den URLs abzurufen, d. h. beim Aufrufen einer Website usw. Dieser Ansatz kommt zum Tragen, wenn eine Webanwendung eine Kommunikation mit den Webservern herstellen muss, um auf die Ressourcen zuzugreifen. Zum Beispiel das Abrufen oder Veröffentlichen der Daten auf einem Webserver oder einer API.

In JavaScript kann dies über den Befehl „ window.fetch() ' Methode. Allerdings in „ node.js “, kann diese Funktionalität durch die Verwendung mehrerer Pakete erreicht werden, z. B. Node-Fetch usw.

In diesem Blog werden folgende Inhaltsbereiche erläutert:







Was ist „Node-Fetch“?

Der ' Knotenabruf „entspricht einem leichtgewichtigen Modul, das die Abruf-API für node.js zugänglich macht. Dieses Modul ermöglicht den Benutzern auch die Verwendung des „ bringen() „Methode in node.js, die größtenteils dem JavaScript ähnelt“ window.fetch() ' Methode.



Syntax(fetch()-Methode)



bringen ( URL [ , Optionen ] ) ;

In dieser Syntax:





  • URL „bezieht sich auf die URL der Ressource, die abgerufen/abgerufen werden muss.
  • Der ' Optionen Der Parameter „fetch()“ wird benötigt, wenn die Methode „fetch()“ außer der Erstellung eines „fetch()“ verwendet werden muss. ERHALTEN ' Anfrage.

Rückgabewert

Diese Funktion ruft ein Antwortobjekt ab, das Informationen zu einer HTTP-Antwort wie folgt enthält:



  • Text: Ruft den Antworttext in Form einer Zeichenfolge ab.
  • Überschriften: Gibt ein Objekt zurück, das die Antworthandler enthält.
  • json(): Analysiert den Antworttext in einem JSON-Objekt.
  • Statustext/Status: Enthält die Informationen zum HTTP-Statuscode.
  • OK: Gibt „ WAHR ” wenn der Status ein 2xx-Statuscode ist.

Voraussetzungen für die Verwendung von Node-Fetch

Die folgenden Voraussetzungen müssen berücksichtigt werden, bevor mit „ Knotenabruf ”:

  • Mindestens die neueste Version 17.5 installiert.
  • Grundkenntnisse in JavaScript.

Wie mache ich HTTP-Anfragen in node.js mit Node-Fetch?

Das Durchführen der HTTP-Anfragen ist ein asynchroner Vorgang, da der Empfang der angeforderten Antwort einige Zeit in Anspruch nimmt. Es gibt zwei Methoden zur Nutzung der asynchronen Prozeduren. Die erste besteht darin, dass der Benutzer auf die Antwort warten und dann mit dem Code fortfahren kann. Der andere führt den Code parallel aus.

Wie fange ich mit Node-Fetch an?

Bevor Sie mit dem „ Knotenabruf ”-Modul, initialisieren Sie ein Knotenprojekt mit Hilfe des unten angegebenen Befehls:

npm init - Und

Durch die Ausführung dieses Befehls wird ein „ package.json ”-Datei im aktuellen Verzeichnis wie folgt:

Installieren Sie nun „ Knotenabruf ”-Modul mit dem folgenden Cmdlet:

npm-Installationsknoten - bringen

Um jedoch eine Zielmodulversion zu installieren, verwenden Sie den folgenden Befehl:

npm-Installationsknoten - bringen@ 2,0

In diesem Fall ist das „ 2,0 ”-Version des Moduls wird installiert.

Notiz: Bevor Sie mit den Beispielen fortfahren, erstellen Sie ein „ index.mjs ”-Datei im Arbeitsbereich, die zum Anwenden der Funktionen verwendet wird.

Beispiel 1: Senden Sie Get-Anfragen über Node-Fetch

Der ' Knotenabruf Das Modul „kann verwendet werden, um Text von einem Webserver oder die Daten über die Rest-API abzurufen.

Das folgende Codebeispiel wurde im erstellten „ index.mjs „-Datei stellt eine einfache Get-Anfrage an die YouTube-Startseite dar:

importieren bringen aus 'Knotenabruf' ;

bringen ( 'https://youtube.com' )

. Dann ( res => res. Text ( ) )

. Dann ( Text => Konsole. Protokoll ( Text ) ) ;

In diesen Codezeilen:

  • Laden Sie „ Knotenabruf ”-Modul und rufen Sie die YouTube-Homepage über die angegebene URL ab, an die die HTTP-Anfrage gestellt wird.
  • Danach verketten Sie die „ Dann() „Methoden zur Verarbeitung der Antwort und Daten aus der gestellten Anfrage.
  • Die frühere „then()“-Methode gibt an, darauf zu warten, die Antwort vom YouTube-Server zu erhalten und sie in ein Textformat umzuwandeln.
  • Die letztgenannte „then()“-Methode bedeutet das Warten auf das Ergebnis der vorherigen Transformation und zeigt es auf der Konsole an.

Ausgabe

Führen Sie nun den Code über das folgende Cmdlet aus:

Knotenindex. mjs

Die Ausführung des obigen Befehls führt dazu, dass das gesamte HTML-Markup der auf der Konsole angezeigten YouTube-Startseite abgerufen wird:

Beispiel 2: Rufen Sie JSON-Daten von der Rest-API ab

In diesem Beispiel wird „ Knotenabruf ” um gefälschte Daten über das zu erhalten JSONPlaceholder RestAPI. Es ist so, dass „ bringen() Die Methode umfasst die URL des Servers und wartet auf eine Antwort:

importieren bringen aus 'Knotenabruf' ;

bringen ( 'https://jsonplaceholder.typicode.com/users' )

. Dann ( res => res. json ( ) )

. Dann ( json => {

Konsole. Protokoll ( „Erster Array-Benutzer ->“ ) ;

Konsole. Protokoll ( json [ 0 ] ) ;

Konsole. Protokoll ( „Erster Array-Benutzername ->“ ) ;

Konsole. Protokoll ( json [ 0 ] . Name ) ;

} )

Führen Sie gemäß diesem Codeblock die folgenden Schritte aus:

  • Der HTTPS-Körper besteht aus JSON-formatierten Daten mit den Daten des Benutzers.
  • Danach wird das „ json() ”-Funktion wird angewendet, um die einzelnen Einträge und die entsprechenden Werte aufzurufen.

Ausgabe

Wenden Sie das unten angegebene Cmdlet an, um den Code auszuführen:

Knotenindex. mjs

Beispiel 3: Post-Anfragen per Node-Fetch

Der ' Knotenabruf „Modul kann auch verwendet werden, um die Anfragen zu posten, anstatt sie abzurufen. Dies kann erreicht werden über die „ bringen() ”-Methode, die einen zusätzlichen Parameter enthält, um POST-Anfragen an einen Server zu stellen.

Mit diesem Parameter können mehrere Optionen zugewiesen werden. Allerdings ist in diesem Fall das „ Methode ',' Körper ' Und ' Kopfzeilen ” wird verwendet. Im Folgenden finden Sie eine Beschreibung der einzelnen Optionen:

  • Der ' Methode Die Option „ legt den Typ der HTTP-Anforderungen fest, d. h. „POST“ in diesem Szenario.
  • Der ' Körper Die Option „beinhaltet den Hauptteil der Anfrage.
  • Der ' Header Die Option „enthält alle erforderlichen Header, d. h. „ Inhaltstyp ' In diesem Szenario.

Fahren Sie nun mit der praktischen Implementierung des Sendens der Post-Anfragen fort, indem Sie ein neues Element an den „JSON-Platzhalter“ anhängen. alle “. Dies geschieht durch Anhängen eines neuen Elements an die Liste mit der Benutzer-ID „476“:

importieren bringen aus 'Knotenabruf' ;

lass alles = {

Benutzer-ID : 476 ,

Website : „Das ist Linuxhint“ ,

vollendet : FALSCH

} ;

bringen ( 'https://jsonplaceholder.typicode.com/todos' , {

Methode : 'POST' ,

Körper : JSON. stringifizieren ( alle ) ,

Kopfzeilen : { 'Inhaltstyp' : 'application/json' }

} ) . Dann ( res => res. json ( ) )

. Dann ( json => Konsole. Protokoll ( json ) ) ;

In diesem Code:

  • Erstellen Sie zunächst ein Todo-Objekt und wandeln Sie es in JSON um, während Sie es an den Text anhängen.
  • Geben Sie nun ebenfalls die URL mit den erforderlichen Optionen als „ bringen() ” optionale Parameter der Methode.
  • Wenden Sie danach das „ JSON.stringify() ”-Methode, um das Objekt in eine formatierte (JSON-)Zeichenfolge umzuwandeln, bevor es an den Webserver gesendet/übertragen wird.
  • Setzen Sie in Zukunft das kombinierte „ Dann() ”-Methoden zum Abrufen der Daten, indem auf die Antwort gewartet, sie in JSON umgewandelt und jeweils an der Konsole protokolliert wird.

Ausgabe

Führen Sie den unten angegebenen Befehl aus, um den Code auszuführen:

Knotenindex. mjs

Was sind die HTTP-Statuscodes?

Bevor Sie mit dem nächsten Beispiel fortfahren, stellen Sie sicher, dass die Antwort ein „ 3xx ” Statuscode, müssen die zusätzlichen Schritte vom Kunden unternommen werden. Ebenso die „ 4xx „Codes stellen eine ungültige Anfrage dar und die „ 5xx „Codes entsprechen den Serverfehlern.

Notiz: Der ' fangen() Die Funktion kann die oben besprochenen Fälle nicht bewältigen, da die Serverkommunikation auf optimierte Weise erfolgt. Daher besteht ein effektiver Ansatz, um sicherzustellen, dass die fehlgeschlagenen Anfragen den Fehler zurückgeben, darin, eine Funktion zu definieren, die den HTTP-Status der Antwort des Servers analysiert.

Beispiel 4: Umgang mit Ausnahmen und Einschränkungen

Es kann verschiedene Einschränkungen oder Ausnahmen bei den gesendeten Anfragen geben, z. B. Probleme mit dem Internet, „ bringen() ” Funktionseinschränkungen usw. Diese Ausnahmen können durch Anhängen des „ fangen() ” Funktion:

Funktion „analysateStatus“. ( X ) {

Wenn ( X. OK ) {

zurückkehren X

} anders {

werfen neu Fehler ( `HTTP-Status in Bezug auf die Antwort -> $ { X. Status } ( $ { X. StatusText } ) ` ) ;

}

}

bringen ( 'https://jsonplaceholder.typicode.com/MissingResource' )

. Dann ( analysierenStatus )

. Dann ( X => X. json ( ) )

. Dann ( json => Konsole. Protokoll ( json ) )

. fangen ( irren => Konsole. Protokoll ( irren ) ) ;

In diesem Codeausschnitt:

  • Definieren Sie zunächst eine Funktion mit dem angegebenen Parameter, bevor Sie die Antwort analysieren, um die auftretenden Einschränkungen zu bewältigen.
  • Fügen Sie nun das „ ansonsten ”-Anweisungen, um den angezeigten Fehler oder eine benutzerdefinierte Einschränkung auszulösen.
  • Wenden Sie danach auf ähnliche Weise das „ bringen() ”-Methode und die zugehörigen „then()“-Methoden, um die Daten abzurufen, indem Sie auf die Antwort warten, sie in JSON umwandeln und sich bei der Konsole anmelden.
  • Schließlich können die Laufzeitausnahmen behandelt werden, indem das „ fangen() ”-Methode am Ende der Versprechenskette.

Ausgabe

Führen Sie abschließend das unten angegebene Cmdlet aus, um den Code auszuführen und die aufgetretenen Ausnahmen auszulösen:

Knotenindex. mjs

Andere Anwendungsfälle von „Node-Fetch“

Der ' Knotenabruf „ kann auch zur Herstellung von „ verwendet werden API-Anfragen ' oder ' Web Scraping “. Lassen Sie uns diese Anwendungsfälle im Detail besprechen.

Nutzung von Node-Fetch zum Erstellen von API-Anfragen

Die API kann in mehreren Szenarien erforderlich sein, um die Zieldaten über eine Back-End-Quelle abzurufen. Die HTTP-Anfragen können über viele Authentifizierungsmethoden verfügen, beispielsweise die Verwendung eines API-Schlüssels, wobei der API-Anbieter einen Schlüssel bereitstellt, der nur dem Benutzer vorbehalten ist. Ein anderer Ansatz zur Abschirmung der API kann über „ Grundlegende Authentifizierung ” in dem ein Header gesendet werden muss, um die API aufzurufen.

Es folgt die Demonstration des letztgenannten Ansatzes, d. h. „Basisauthentifizierung“ in der Post-Anfrage mit Hilfe des „ bringen() ' Methode:

( asynchron ( ) => {

const X = warte auf Abholung ( 'http://httpbin.org/post' , {

Methode : 'POST' ,

Kopfzeilen : {

'Genehmigung' : „Grundlegendes $ { Bruder ( 'Passwort' ) } `

} ,

Körper : JSON. stringifizieren ( {

'Schlüssel' : 'Wert'

} )

} ) ;

const Ergebnis = warte auf x. Text ( ) ;

Konsole. Protokoll ( Ergebnis ) ;

} ) ( ) ;

In der obigen Demonstration wird ein Header mit einem „ base64 ” codierte Zeichenfolge des Formats „ Passwort “.

Nutzung von Node-Fetch für Web Scraping

Web Scraping „bezieht sich auf die Technik, mit der die Daten/Inhalte von den Websites abgerufen und analysiert werden. Dieses Parsen wird über die „ Cheerio ' Bibliothek.

Nachfolgend finden Sie eine Demonstration zum Abrufen des Seitentitels über „ bringen() „Methode und“ Cheerio ' Bibliothek:

const lib = erfordern ( 'jubeln' ) ;

( asynchron ( ) => {

const X = warte auf Abholung ( 'https://linuxhint.com/' ) ;

const Und = warte auf x. Text ( ) ;

const $ = lib. Belastung ( Und ) ;

Konsole. Protokoll ( $ ( 'Titel' ) . Erste ( ) . Text ( ) ) ;

} ) ( ) ;

Dieses Beispiel ruft die Kachel des „ Linux ”Titel der Website.

Abschluss

Die HTTP-Anfragen in node.js können mit Node-Fetch gestellt werden, indem Get-Anfragen gesendet, JSON-Daten von der REST-API abgerufen oder Post-Anfragen gesendet werden. Außerdem können die Ausnahmen und Einschränkungen effektiv über die „“ gehandhabt werden. fangen() ” Funktion.