


Introduction aux fonctionnalités du middleware Express4.x (exemple de code)
Le contenu de cet article est une introduction aux fonctionnalités du middleware Express4.x (exemples de code). Il a une certaine valeur de référence. J'espère qu'il sera utile. vous aide.
Les applications express sont essentiellement une série d'appels de fonctions middleware qui sont exécutés dans un pipeline. Vous pouvez imaginer un véritable tuyau transportant de l’eau. L'eau est pompée à une extrémité puis passe à travers diverses jauges et vannes avant d'atteindre sa destination. Une partie importante de cette analogie est la question de l’ordre. L’effet est différent si vous placez le manomètre avant la vanne ou après. De même, si vous disposez d'une valve qui injecte quelque chose dans l'eau, tout ce qui est « en aval » de la valve contiendra cet ingrédient nouvellement ajouté. Dans un programme Express, le middleware est inséré dans le pipeline en appelant app.use.
Avant Express 4.0, ce pipeline était un peu compliqué car le routeur devait être connecté explicitement. Selon l'endroit où vous vous connectez au routeur, le routage peut être dans le désordre, ce qui rend l'ordre du pipeline encore moins clair lorsque vous mélangez un middleware et des gestionnaires de routage. Dans Express 4.0, les middlewares et les gestionnaires de routes sont appelés dans l'ordre dans lequel ils sont connectés, ce qui rend l'ordre plus clair.
Les processeurs de route (app.get, app.post, etc., souvent appelés collectivement app.VERB) peuvent être considérés comme des middlewares qui ne gèrent que des verbes HTTP spécifiques (GET, POST, etc.). De même, le middleware peut également être considéré comme un processeur de route capable de gérer tous les verbes HTTP (essentiellement équivalent à app.all, qui peut gérer n'importe quel verbe HTTP ; il y aura des différences subtiles pour les verbes spéciaux tels que PURGE, mais pour les verbes ordinaires. en ce qui concerne les prédicats, l'effet est le même).
Le premier paramètre du processeur de route doit être un chemin. Si vous souhaitez qu'un itinéraire corresponde à tous les chemins, utilisez simplement /*. Le middleware peut également prendre un chemin comme premier paramètre, mais il est facultatif (si ce paramètre est omis, il correspondra à tous les chemins comme si /* était spécifié)
Router les processeurs et les middlewares Il y a une fonction de rappel dans les paramètres du fichier, et cette fonction a 2, 3 ou 4 paramètres (techniquement elle peut aussi avoir 0 ou 1 paramètre, mais ces formes n'ont aucun sens). S'il y a 2 ou 3 paramètres, les deux premiers paramètres sont les objets de requête et de réponse, et le troisième paramètre est la fonction suivante. S'il y a 4 paramètres, il devient un middleware de gestion des erreurs et le premier paramètre devient l'objet d'erreur, suivi de la requête, de la réponse et des objets suivants. Si next() n'est pas appelé, le pipeline sera terminé et il n'y aura plus de traitement par les processeurs ou le middleware.
Si vous n'appelez pas next(), vous devez envoyer une réponse au client (res.send, res.json, res.render, etc.) ; le client se bloquera et entraînera finalement un délai d'attente. Si next() est appelé, il n'est généralement pas approprié d'envoyer une réponse au client. Si vous l'envoyez, les middlewares ou les gestionnaires de routes suivants dans le pipeline s'exécuteront toujours, mais toutes les réponses qu'ils enverront seront ignorées.
var express = require('express') var app = express() var requestTime = function (req, res, next) { req.requestTime = Date.now() console.log(req.requestTime ); next() } var requestUser = function (req, res, next) { console.log('welcome'); next() } app.use(requestTime) app.get('/', function (req, res) { console.log('//welcome'); var responseText = 'Hello World!<br>' responseText += '<small>Requested at: ' + req.requestTime + '</small>' res.send(responseText) }) app.use(requestUser) app.listen(3000)
Accès 127.0.0.1:3000 temps de sortie et //bienvenue n'exécutera pas le code middleware requestUser 1552630945571//bienvenue
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Cet article vous donnera une compréhension approfondie de la mémoire et du garbage collector (GC) du moteur NodeJS V8. J'espère qu'il vous sera utile !

Le service Node construit sur une base non bloquante et piloté par les événements présente l'avantage d'une faible consommation de mémoire et est très adapté à la gestion de requêtes réseau massives. Dans le contexte de demandes massives, les questions liées au « contrôle de la mémoire » doivent être prises en compte. 1. Le mécanisme de récupération de place du V8 et les limitations de mémoire Js sont contrôlés par la machine de récupération de place

Le choix d'une image Docker pour Node peut sembler trivial, mais la taille et les vulnérabilités potentielles de l'image peuvent avoir un impact significatif sur votre processus CI/CD et votre sécurité. Alors, comment choisir la meilleure image Docker Node.js ?

Le module de fichiers est une encapsulation des opérations de fichiers sous-jacentes, telles que l'ajout de lecture/écriture/ouverture/fermeture/suppression de fichiers, etc. La plus grande caractéristique du module de fichiers est que toutes les méthodes fournissent deux versions de **synchrone** et ** asynchrone**, with Les méthodes avec le suffixe sync sont toutes des méthodes de synchronisation, et celles qui n'en ont pas sont toutes des méthodes hétérogènes.

Node 19 est officiellement publié. Cet article vous donnera une explication détaillée des 6 fonctionnalités majeures de Node.js 19. J'espère qu'il vous sera utile !

Comment Node.js fait-il le GC (garbage collection) ? L’article suivant vous guidera à travers cela.

La boucle d'événements est un élément fondamental de Node.js et permet une programmation asynchrone en garantissant que le thread principal n'est pas bloqué. Comprendre la boucle d'événements est crucial pour créer des applications efficaces. L'article suivant vous donnera une compréhension approfondie de la boucle d'événements dans Node. J'espère qu'il vous sera utile !

La raison pour laquelle le nœud ne peut pas utiliser la commande npm est que les variables d'environnement ne sont pas configurées correctement. La solution est la suivante : 1. Ouvrez "Propriétés système" ; 2. Recherchez "Variables d'environnement" -> "Variables système", puis modifiez l'environnement. variables ; 3. Recherchez l'emplacement du dossier nodejs ; 4. Cliquez sur "OK".
