Maison >interface Web >js tutoriel >Créez facilement un serveur nodejs (5) : event handler_node.js

Créez facilement un serveur nodejs (5) : event handler_node.js

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBoriginal
2016-05-16 16:25:491096parcourir

Afin de fournir différents commentaires aux différents utilisateurs, nous introduisons un module de gestion d'événements.

Ce module s'appelle requestHandlers. Nous ajoutons d'abord deux fonctions d'espace réservé : start() et upload().

Le code requestHandlers.js est le suivant :

Copier le code Le code est le suivant :

fonction start() {
console.log("Ceci est appelé lors de l'accès à /star.");
>

fonction upload() {
console.log("Ceci est appelé lors de l'accès à /upload.");
>

exports.start = start;
exports.upload = télécharger;

Dans une application réelle, le nombre de gestionnaires de requêtes continuera d'augmenter, et nous ne voulons certainement pas avoir à terminer la requête dans la route à chaque fois qu'il y a une nouvelle URL ou un nouveau gestionnaire de requêtes

Cartographier le gestionnaire et le lancer encore et encore.

De plus, nous ne voulons pas avoir beaucoup de if request == x then call handler y dans le routage, ce qui donnerait au code un aspect désordonné et peu professionnel.

Ici, j'utiliserai le concept de tableaux associatifs pour gérer cette exigence. Nous passons une série de gestionnaires de requêtes via un objet, et nous devons injecter cet objet dans la fonction route() de manière faiblement couplée.

Nous introduisons d'abord cet objet dans le fichier principal index.js :

Copier le code Le code est le suivant :

var serveur = require("./server");
var routeur = require("./router");
var requestHandlers = require("./requestHandlers");

var handle = {};
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;

server.start(router.route, handle);

Par exemple, si je souhaite ajouter un mappage /show, ajoutez simplement handle["/show"] requestHandlers.show;

Haha, est-ce que cela rend le code plus concis et ordonné ? !

Ensuite, nous transmettons l'objet handle au serveur et modifions server.js comme suit :

Copier le code Le code est le suivant :
var http = require("http");
var url = require("url");
fonction start(route, handle) {
function onRequest (demande, réponse) {
var chemin d'accès = url.parse(request.url).chemin d'accès;
Console.log("Demande de " chemin d'accès " reçue.");
route(handle, chemin);
réponse.writeHead(200, {"Content-Type": "text/plain"});
réponse.write("Bonjour tout le monde");
réponse.end();
>
http.createServer(onRequest).listen(8888);
console.log("Le serveur a démarré.");
>
exports.start = start;

Modifiez en conséquence la fonction route() dans le fichier route.js :

Copier le code Le code est le suivant :
function route(handle, chemin) {
console.log("Sur le point d'acheminer une requête pour " pathname);
if (typeof handle[pathname] === 'function') {
handle[chemin d'accès]();
} autre {
console.log("Aucun gestionnaire de requêtes trouvé pour " pathname);
>
>
exports.route = route;

Nous transmettons l'objet handle au serveur en paramètre, qui est ensuite reçu par le routeur. Enfin, le routeur détermine si le gestionnaire de requêtes correspondant au chemin actuel existe. S'il existe, la fonction correspondante est appelée.

Nous pouvons obtenir la fonction de traitement des requêtes de l'objet passé de la même manière que nous obtenons des éléments du tableau associatif, nous avons donc une expression simple et fluide sous la forme de handle[pathname]();, qui ressemble à As mentionné plus tôt : "Hé, s'il te plaît, aide-moi avec ce chemin".

De cette façon, nous pouvons traiter différentes demandes différemment.

Dans la section suivante, nous modifierons davantage le code pour permettre au serveur d'effectuer certaines opérations de feedback réelles.

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn