Notes d'étude Nodejs NET module_node.js
1, analyse d'ouverture
À partir d'aujourd'hui, nous approfondirons l'étude du module spécifique. Cet article est le troisième de cette série d'articles. Les deux premiers articles sont principalement théoriques. Je pense que tout le monde apprendra des deux premiers articles.
J'ai aussi une compréhension de base de NodeJS, donc ça va ! ! ! Frappons pendant que le fer est chaud, continuons à réaliser NodeJS jusqu'au bout. Sans plus tarder, passons directement au sujet d'aujourd'hui « Module Net ». Alors, comment faut-il comprendre « Net » ?A quoi sert-il ? (
Le module peut être utilisé pour créer un serveur Socket ou un client Socket. Les deux modules les plus basiques pour la communication de données NodeJS sont Net et Http. Le premier est basé sur l'encapsulation Tcp, et le second est essentiellement une couche Tcp, mais une comparaison a été faite. Encapsulation de données multiples, nous la considérons comme la couche de présentation). Net
Il n'est pas difficile de voir sur la figure que HttpServer hérite de la classe Net, possède des capacités de communication associées et effectue davantage d'encapsulation de données. Nous le considérons comme une couche de présentation plus avancée.
Connaissances étendues (ce qui suit est le code source de "hérites") :
ctor.super_ = superCtor;
ctor.prototype = Objet.create(superCtor.prototype, {
Constructeur : {
Valeur : cteur,
énumérable : faux,
inscriptible : vrai,
Configurable : vrai
>
});
};
Je viens de donner un bref aperçu, qui contient quelques concepts couramment utilisés. Voici une brève introduction pour vulgariser les concepts :
(1), TCP/IP------Le protocole TPC/IP est un protocole de couche de transport, qui résout principalement la façon dont les données sont transmises dans le réseau.
(2), Socket------socket est l'encapsulation et l'application du protocole TCP/IP (niveau programme).
(3), Http------HTTP est un protocole de couche application, qui résout principalement la façon de conditionner les données.
(4), modèle de réseau à sept couches ------ couche physique, couche liaison de données, couche réseau, couche transport, couche session, couche présentation et couche application.
Pour résumer : Socket est une encapsulation du protocole TCP/IP. Socket lui-même n'est pas un protocole, mais une interface d'appel (API).
Cela constitue certaines des interfaces de fonctions les plus basiques que nous connaissons, telles que Créer, Écouter, Connecter, Accepter, Envoyer, Lire et Écrire, etc.
TCP/IP n'est qu'une pile protocolaire, tout comme le mécanisme d'exploitation du système d'exploitation, il doit être implémenté concrètement, et en même temps il doit fournir une interface d'exploitation externe
En fait, le TCP de la couche transport est basé sur le protocole IP de la couche réseau, et le protocole HTTP de la couche application est basé sur le protocole TCP de la couche transport. Le Socket lui-même n'est pas un protocole. mentionné ci-dessus, il s'agit simplement de Fournit une interface pour la programmation TCP ou UDP.
Deux, faites-en l'expérience
D'accord, nous avons le concept, voici un exemple :1, créez server.js
var server = net.createServer(function(c) { // Écouteur de connexion
console.log("Serveur connecté") ;
c.on("fin", function() {
console.log("Le serveur a été déconnecté") ;
}) ;
c.write("Bonjour Bigbear !rn") ;
c.pipe(c) ;
}) ;
server.listen(8124, function() { // Écouteur
Console.log("Le serveur est lié") ;
}) ;
var client = net.connect({
Port : 8124
},function(){ // connecter l'écouteur
console.log("Le client est connecté") ;
client.write('Bonjour, Bébé !rn') ;
});
client.on("données", fonction(données) {
console.log(data.toString()) ;
client.end() ;
});
client.on("end", function(){
console.log("Client déconnecté") ;
}) ;
Analysez-le :
Serveur------net.createServer
Créez un service TCP. Ce service est lié (server.listen) sur le port 8124. Après avoir créé le serveur, nous voyons une fonction de rappel,
Lors de l'appel de la fonction ci-dessus, transmettez un paramètre. Ce paramètre est également une fonction et accepte le socket. Il s'agit d'un canal construit par d'autres méthodes. Sa fonction est pour l'interaction des données.
Le canal doit être établi par le client pour saluer le serveur. Si aucun client n'accède au serveur à ce moment, ce socket n'existera pas.
客户端------net.connect
Comme son nom l'indique, il s'agit de se connecter au serveur. Le premier paramètre est l'objet. Définissez le port sur 8124, qui est le port sur lequel notre serveur écoute. Puisque le paramètre host n'est pas défini, le. la valeur par défaut est localhost (local) .
Dans le serveur, le socket est une extrémité du tuyau, tandis que dans le client, le client lui-même est une extrémité du tuyau. Si plusieurs clients se connectent au serveur, le serveur créera plusieurs nouveaux sockets, chaque socket correspondant à un client.
Résultat de l'exécution :
3. Présentation du cas
(1), le code suivant est simplement le serveur qui envoie un morceau de texte au client, complétant ainsi la communication unidirectionnelle du serveur vers le client.
// Sever --> Communication unidirectionnelle du client
var net = require('net');
var chatServer = net.createServer();
chatServer.on('connexion', fonction(client) {
client.write('Hi!n'); // Le serveur envoie des informations au client, en utilisant la méthode write()
client.write('Bye!n');
client.end(); // Le serveur termine la session
});
chatServer.listen(9000);
Test avec Telnet : telnet127.0.0.1:9000
Après avoir exécuté telnet, connectez-vous au point de service, envoyez les caractères Hi Bye ! et terminez immédiatement le programme serveur pour mettre fin à la connexion.
Et si nous voulons que le serveur reçoive des informations du client ?
Vous pouvez écouter l'événement server.data et ne pas mettre fin à la connexion (sinon elle se terminera immédiatement et ne pourra pas accepter les messages du client).
(2), écoutez l'événement server.data et ne terminez pas la connexion (sinon elle se terminera immédiatement et ne pourra pas accepter les messages du client).
// Sur la base du premier, réaliser la communication Client --> Sever, afin qu'il s'agisse d'une communication bidirectionnelle
var net = require('net');
var chatServer = net.createServer(),
listeclient = [];
chatServer.on('connexion', fonction(client) {
// JS peut librement ajouter des propriétés aux objets. Ici, nous ajoutons un attribut personnalisé de nom pour indiquer quel client (en fonction de l'adresse et du port du client)
client.name = client.remoteAddress ':' client.remotePort
client.write('Bonjour ' client.name '!n');
clientList.push(client);
client.on('données', fonction(données) {
Broadcast(data, client);//Accepter les informations du client
});
});
fonction diffusion (message, client) {
for(var i=0;i
clientList[i].write(client.name " dit " message);
}
>
>
chatServer.listen(9000);
Ce qui précède est-il un code entièrement fonctionnel ? Nous avons dit qu'il y avait un autre problème qui n'avait pas été pris en compte : une fois qu'un client sort, il est toujours conservé dans la clientList, ce qui est évidemment un pointeur nul.
(3), gérer clientList
chatServer.on('connexion', fonction(client) {
client.name = client.remoteAddress ':' client.remotePort
client.write('Bonjour ' client.name '!n');
clientList.push(client)
client.on('données', fonction(données) {
Diffusion (données, client)
})
client.on('end', function() {
ClientList.splice(clientList.indexOf(client), 1); // Supprime l'élément spécifié dans le tableau.
})
})
NodeTCPAPI nous a fourni l'événement de fin, qui se produit lorsque le client met fin à la connexion avec le serveur.
(4), optimiser la diffusion
fonction diffusion(message, client) {
var nettoyage = []
pour(var i=0;i
If(clientList[i].writable) { // Vérifiez d'abord si les sockets sont accessibles en écriture
clientList[i].write(client.name " dit " message)
} autre {
cleanup.push(clientList[i]) // S'il n'est pas accessible en écriture, récupérez-le et détruisez-le. Avant la destruction, Socket.destroy() doit être utilisé pour le détruire à l'aide de la méthode API.
clientList[i].destroy()
>
>
} //Supprimez les nœuds morts de la boucle d'écriture pour éviter de détruire l'index de la boucle
pour(i=0;i
>
>
Notez qu'une fois que "end" n'est pas déclenché, une exception se produira, donc le travail d'optimisation est effectué.
(5), NetAPI fournit également un événement d'erreur pour capturer les exceptions client
client.on('erreur', fonction(e) {
console.log(e);
});
Quatre, résumé
1. Comprendre les concepts pertinents au début
2. Comprendre la relation entre les modules Http et Net
3. En combinaison avec les exemples de cet article, découvrez les API pertinentes pour vous entraîner
4. Idées de communication entre le client socket et le serveur
5. Si vous êtes intéressé, vous pouvez améliorer l'exemple du salon de discussion

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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Sujets chauds

Node.js est un environnement d'exécution JavaScript côté serveur, tandis que Vue.js est un framework JavaScript côté client permettant de créer des interfaces utilisateur interactives. Node.js est utilisé pour le développement côté serveur, comme le développement d'API de service back-end et le traitement des données, tandis que Vue.js est utilisé pour le développement côté client, comme les applications monopage et les interfaces utilisateur réactives.

Node.js peut être utilisé comme framework backend car il offre des fonctionnalités telles que des performances élevées, l'évolutivité, la prise en charge multiplateforme, un écosystème riche et une facilité de développement.

Pour vous connecter à une base de données MySQL, vous devez suivre ces étapes : Installez le pilote mysql2. Utilisez mysql2.createConnection() pour créer un objet de connexion contenant l'adresse de l'hôte, le port, le nom d'utilisateur, le mot de passe et le nom de la base de données. Utilisez connection.query() pour effectuer des requêtes. Enfin, utilisez connection.end() pour mettre fin à la connexion.

Les variables globales suivantes existent dans Node.js : Objet global : global Module principal : processus, console, nécessiter Variables d'environnement d'exécution : __dirname, __filename, __line, __column Constantes : undefined, null, NaN, Infinity, -Infinity

Il existe deux fichiers liés à npm dans le répertoire d'installation de Node.js : npm et npm.cmd. Les différences sont les suivantes : différentes extensions : npm est un fichier exécutable et npm.cmd est un raccourci de fenêtre de commande. Utilisateurs Windows : npm.cmd peut être utilisé à partir de l'invite de commande, npm ne peut être exécuté qu'à partir de la ligne de commande. Compatibilité : npm.cmd est spécifique aux systèmes Windows, npm est disponible multiplateforme. Recommandations d'utilisation : les utilisateurs Windows utilisent npm.cmd, les autres systèmes d'exploitation utilisent npm.

Les principales différences entre Node.js et Java résident dans la conception et les fonctionnalités : Piloté par les événements ou piloté par les threads : Node.js est piloté par les événements et Java est piloté par les threads. Monothread ou multithread : Node.js utilise une boucle d'événements monothread et Java utilise une architecture multithread. Environnement d'exécution : Node.js s'exécute sur le moteur JavaScript V8, tandis que Java s'exécute sur la JVM. Syntaxe : Node.js utilise la syntaxe JavaScript, tandis que Java utilise la syntaxe Java. Objectif : Node.js convient aux tâches gourmandes en E/S, tandis que Java convient aux applications de grande entreprise.

Oui, Node.js est un langage de développement backend. Il est utilisé pour le développement back-end, notamment la gestion de la logique métier côté serveur, la gestion des connexions à la base de données et la fourniture d'API.

Node.js et Java ont chacun leurs avantages et leurs inconvénients en matière de développement Web, et le choix dépend des exigences du projet. Node.js excelle dans les applications en temps réel, le développement rapide et l'architecture de microservices, tandis que Java excelle dans la prise en charge, les performances et la sécurité de niveau entreprise.
