Heim > Web-Frontend > js-Tutorial > Machen Sie sich eingehend mit dem HTTP-Modul vertraut

Machen Sie sich eingehend mit dem HTTP-Modul vertraut

青灯夜游
Freigeben: 2022-06-09 19:28:52
nach vorne
2243 Leute haben es durchsucht

Dieser Artikel wird Ihnen helfen, mehr über das http-Modul zu erfahren und den Grundstein für das Schreiben von Schnittstellen zu legen. Ich hoffe, er wird Ihnen hilfreich sein!

Machen Sie sich eingehend mit dem HTTP-Modul vertraut

1. Webserver

Was ist ein Webserver?

Wenn die Anwendung (Client) eine bestimmte Ressource benötigt, kann sie die Ressource über HTTP an einen Server anfordern; der Server, der die Ressource bereitstellt, ist ein Webserver.

1.2 Zwei Möglichkeiten zum Erstellen eines ServersMachen Sie sich eingehend mit dem HTTP-Modul vertraut

http.createServer gibt das Serverobjekt zurückDie unterste Ebene verwendet tatsächlich das direkte neue Serverobjekt

  • 1.3 Anforderungsobjekt

Machen Sie sich eingehend mit dem HTTP-Modul vertraut

Das Anforderungsobjekt kapselt alle vom Client an unseren Server übergebenen Informationen.

Die URL dieser Anforderung muss vom Server je nach URL unterschiedlich verarbeitet werden.

Die Anforderungsmethode von Bei dieser Anfrage sind beispielsweise die in GET- und POST-Anfragen übergebenen Parameter und Verarbeitungsmethoden unterschiedlich.

  • Die Header dieser Anfrage enthalten auch einige Informationen, z. B. Clientinformationen, Format zum Empfangen von Daten, unterstützte Codierungsformate usw . …

  • Regelmäßige Anfrage:

1.3.1 Anfrage-URL

Machen Sie sich eingehend mit dem HTTP-Modul vertraut

Wenn der Client eine Anfrage sendet, werden andere Daten angefordert, dann werden verschiedene Anfrageadressen übergeben Serverseitig müssen unterschiedliche Antworten basierend auf unterschiedlichen Anforderungsadressen erfolgen.

Machen Sie sich eingehend mit dem HTTP-Modul vertrautWenn die Anforderungsadresse des Benutzers auch einige zusätzliche Parameter enthält, wie sollten wir sie analysieren?

Wir können das URL-Modul verwenden. Unter anderem bietet das URL-Modul praktische Tools für die URL-Verarbeitung und -Analyse.

URL importieren const url = require('url')

Angenommen, unsere Anforderungsdaten lauten:

Das Ergebnis der Konsolenanalyse der URL ist:


Der Pfadname ist der letzte Pfad, den wir erhalten müssen. Unser Ziel ist es, Benutzernamen und Passwort in der Abfrage getrennt zu erhalten. Machen Sie sich eingehend mit dem HTTP-Modul vertraut

Querystring-Modul importieren

const http = require("http")const url = require('url')const qs = require('querystring')// 1. 创建服务器const server = http.createServer((req, res) => {
  // 使用内置模块
  const{ pathname,query } = url.parse(req.url)
  if(pathname === '/login'){
    console.log(query);
    console.log(qs.parse(query));
    const { username, password } = qs.parse(query)
    console.log(username,password);
    res.end('请求结束')
  }});// 2. 设置端口号并启动服务器server.listen(8888,'0.0.0.0',()=>{
  console.log("服务器启动成功~");})
Nach dem Login kopieren

Machen Sie sich eingehend mit dem HTTP-Modul vertraut✅Ergebnisse der Konsolenausgabe:

const qs = require('querystring');

1.3.2-Anfragemethode

  • In der Restful-Spezifikation (Designstil) sollten wir Daten hinzufügen, löschen, ändern und überprüfen verschiedene Methoden Anforderungsmethode: Machen Sie sich eingehend mit dem HTTP-Modul vertraut
GET: Daten abfragen;

PATCH: Daten aktualisieren;

DELETE: Daten löschen

    Wir können unterschiedliche Verarbeitungen durchführen, indem wir verschiedene Anforderungsmethoden (Methoden) beurteilen. .
  • Angenommen, das Folgende sind unsere JSON-Anfragedaten im Hauptteil -> Wie kann unser Server Benutzernamen und Passwort erhalten?
  • ...
Bewerbung /json stellt einen JSON-Typ dar;

application/xml stellt einen XML-Typ dar;

multipart/form-data stellt eine hochgeladene Datei dar; Dateigröße und -länge

Machen Sie sich eingehend mit dem HTTP-Modul vertrautkeep-alive:

  • http basiert auf dem TCP-Protokoll, wird jedoch normalerweise sofort nach einer Anfrage und Antwort unterbrochen.
  • Wenn Sie in http1.0 die Verbindung weiterhin aufrechterhalten möchten: ①Der Browser muss eine Verbindung hinzufügen: Behalten Sie die Anfrage bei header -alive; ② Der Server muss „connection:key-alive“ in den Antwortheader einfügen. ③ Wenn der Client erneut eine Anfrage stellt, wird dieselbe Verbindung verwendet und die direkte Partei unterbricht die Verbindung , alle Verbindungen sind standardmäßig auf Verbindung: Keep-Alive: ① Verschiedene Webserver haben unterschiedliche Keep-Alive-Zeiten. ② Die Standardeinstellung in Node ist 5s
  • **accept-encoding:** Informieren Sie den Server über das unterstützte Dateikomprimierungsformat vom Client können beispielsweise js-Dateien die GZIP-Codierung verwenden, entsprechend .gz-Dateien

**accept: **Informieren Sie den Server, dass der Client den Dateiformattyp akzeptieren kann

**user-agent: ** Kundenbezogene Informationen;

1.4 Antwortobjekt

1.4.1 Antwort-Antwortobjekt

Wenn wir dem Client Antwortergebnisdaten geben möchten, können wir dies auf zwei Arten tun:

Schreiben Methode: Auf diese Weise werden die Daten direkt geschrieben, der Stream wird jedoch nicht geschlossen.
  • Endmethode: Bei dieser Methode werden die letzten Daten geschrieben und der Stream wird nach dem Schreiben geschlossen Rufen Sie end und close nicht auf, der Client wartet immer auf die Ergebnisse.
  • 1.4.2 Antwort-Antwortcode

Der HTTP-Statuscode (HTTP-Statuscode) ist ein numerischer Code, der zur Darstellung des HTTP-Antwortstatus verwendet wird:

Es gibt viele HTTP-Statuscodes, die dem Client übergeben werden können je nach Situation. Geben Sie unterschiedliche Statuscodes zurück.

Gemeinsame Statuscodes werden auch in nachfolgenden Projekten verwendet

Begründungssatz
  • 1xx
Informativ (Informationsstatuscode) Die akzeptierte Anfrage wird verarbeitet3xx UmleitungClient-FehlerServerfehler (Serverfehler) Allgemeine Antwortcodes: Statuscode Beschreibung Status Beschreibung

2xxErfolgreich (Erfolgsstatuscode) Die Anfrage wurde normal verarbeitet
Zusätzliche Aktion ist erforderlich, um die Anfrage abzuschließen 4xx
Der Server konnte die Anfrage nicht verarbeiten 5xx
Server Fehlerverarbeitungsanforderung

200OK 401UnauthorizedVerbotenNicht gefundenInterner Serverfehler1.4.3 Antwort-Antwort-Headerres.setHeader: jeweils eine Header-Information schreiben; res.writeHead: Header und Status gleichzeitig schreiben
Anfrage erfolgreich. Wird im Allgemeinen für GET- und POST-Anfragen verwendet 400Bad Request Der Syntaxfehler der Client-Anfrage kann vom Server nicht verstanden werden
Die Anfrage erfordert eine Benutzeridentitätsauthentifizierung 403
Der Server versteht die Anfrage des Clients, weigert sich jedoch, die Anfrage auszuführen 404
Der Server kann die Ressource (Webseite) basierend auf der Anfrage des Clients nicht finden. Mit diesem Code können Website-Designer eine personalisierte Seite „Die von Ihnen angeforderte Ressource kann nicht gefunden werden“ einrichten. 500
Interner Serverfehler, die Anfrage konnte nicht abgeschlossen werden Nicht verfügbar Aufgrund von Überlastung oder Systemwartung kann der Server vorübergehend keine Clientanfragen verarbeiten. Die Länge der Verzögerung kann in den Retry-After-Header-Informationen des Servers enthalten sein
Statuscode festlegen:
Hauptsächlich Header-Informationen zurückgeben Es gibt zwei Möglichkeiten:
Weitere Informationen zu Knoten finden Sie unter :

nodejs Tutorial !

Das obige ist der detaillierte Inhalt vonMachen Sie sich eingehend mit dem HTTP-Modul vertraut. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage