• Share
  • Email
  • Embed
  • Like
  • Save
  • Private Content
173544 introduction-aux-sockets
 

173544 introduction-aux-sockets

on

  • 256 views

 

Statistics

Views

Total Views
256
Views on SlideShare
256
Embed Views
0

Actions

Likes
0
Downloads
12
Comments
0

0 Embeds 0

No embeds

Accessibility

Categories

Upload Details

Uploaded via as Adobe PDF

Usage Rights

© All Rights Reserved

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Processing…
Post Comment
Edit your comment

    173544 introduction-aux-sockets 173544 introduction-aux-sockets Document Transcript

    • Introduction aux sockets Par SoftDeath www.siteduzero.com Licence Creative Commons 2 2.0 Dernière mise à jour le 15/05/2012
    • 2/24 Sommaire Sommaire ........................................................................................................................................... 2 Lire aussi ............................................................................................................................................ 1 Introduction aux sockets .................................................................................................................... 3 Récupérer une adresse IP avec InetAddress ................................................................................................................... 4 Qu'est-ce qu'un socket ? ................................................................................................................................................... 5 Échange de message ....................................................................................................................................................... 8 Côté Serveur ............................................................................................................................................................................................................. 11 Côté Client ................................................................................................................................................................................................................. 11 Utilisation des threads ............................................................................................................................................................................................... 11 TP : un mini-chat entre le client et le serveur ! ................................................................................................................ 13 Q.C.M. ............................................................................................................................................................................. 22 Partager ..................................................................................................................................................................................................................... 23 www.siteduzero.com
    • Sommaire 3/24 Introduction aux sockets Par SoftDeath Mise à jour : 15/05/2012 Difficulté : Difficile 1 536 visites depuis 7 jours, classé 91/797 Bienvenue dans mon tout premier mini-tutoriel consacré aux sockets en langage Java. On ne va pas tout apprendre sur les sockets mais étudier le plus important concernant ces classes du répertoire java.net. Avant de vous lancer dans la lecture de ce tutoriel, les deux premières parties de cysboy sur le langage Java ainsi que la lecture de celui sur les threads et les flux d'entrées et sorties (1/2) sont primordiales pour bien suivre le cours ! Je vous recommande également de lire le chapitre de Dalshim Bien fermer ses threads en Java si vous voulez bien maîtriser la fermeture de vos threads. Les sockets servent à communiquer entre deux hôtes appelés Client / Serveur à l'aide d'une adresse IP et d'un port que j'appelle prise ; ces sockets permettront de gérer des flux entrant et sortant afin d'assurer une communication entre les deux (le client et le serveur), soit de manière fiable à l'aide du protocole TCP/IP, soit non fiable mais plus rapide avec le protocole UDP. Nous allons étudier le premier mode, le mode TCP/IP… V ce qu'on peut réaliser à l'aide des sockets : oici des jeux en ligne ; des systèmes distribués ; des espaces messengers comme MSN Messenger, Yahoo Messenger, … ; des applications comme BitComet permettant de gérer les fichiers .torrent que vous connaissez ; et bien d'autres choses. Les sockets sont utilisés dans plusieurs autres langages, tels que : le langage C : ( lien vers un tutoriel) ; le langage C++ : (lien vers un autre tutoriel) ; le langage PHP : (lien vers un troisième tutoriel) ; l'Action Script : (aller lire le tutoriel) ; le Erlang : (lien vers le tuto concerné) ; et bien d'autres. Lire les parties « histoire » et « définitions » de tutoriels ci-dessus ne vous fera pas de mal. Ne tardons pas et commençons. Sommaire du tutoriel : Récupérer une adresse IP avec InetAddress Qu'est-ce qu'un socket ? Échange de message TP : un mini-chat entre le client et le serveur ! Q.C.M. www.siteduzero.com
    • Introduction aux sockets 4/24 Récupérer une adresse IP avec InetAddress Le package java.net de la plate-forme Java fournit une classe InetAddress qui nous permet de récupérer et manipuler son adresse internet, IP pour les intimes. Cette classe n'a pas de constructeur, pour pouvoir avoir une instance de cette classe on a besoin des méthodes de classe. V les méthodes dont je vous parle : oici getLocalHost() : elle retourne un objet qui contient l'adresse IP de la machine locale. getByName(String nom_de_l_machine) : elle retourne un objet qui contient l'adresse IP de la machine dont le nom est passé en paramètre. getAllByName(String nom_de_l_machine) : elle retourne un tableau d'objets qui contient l'ensemble d'adresses IP de la machine qui correspond au nom passé en paramètre. A présent, voyons les méthodes applicables à un objet de cette classe : getHostName() : elle retourne le nom de la machine dont l'adresse est stockée dans l'objet. getAddress() : elle retourne l'adresse IP stockée dans l'objet sous forme d'un tableau de 4 octets. toString() : elle retourne un String qui correspond au nom de la machine et son adresse. Et pour terminer un petit exemple : Code : Java import java.net.InetAddress; import java.net.UnknownHostException; public class Adressage { public static void main(String[] zero) { InetAddress LocaleAdresse ; InetAddress ServeurAdresse; try { LocaleAdresse = InetAddress.getLocalHost(); System.out.println("L'adresse locale est : "+LocaleAdresse ); ServeurAdresse= InetAddress.getByName("www.siteduzero.com"); System.out.println("L'adresse du serveur du site du zéro est : "+ServeurAdresse); } catch (UnknownHostException e) { } } e.printStackTrace(); } Et le résultat est : Code : Console L'adresse locale est : softdeath/239.254.78.177 L'adresse du serveur du site du zéro est : www.siteduzero.com/80.248.219.123 www.siteduzero.com
    • Introduction aux sockets 5/24 Fastoche, hein ? La classe InetAdress peut lever une exception de type UnknownHostException, tâchez de ne pas l'oublier ! Nous savons maintenant comment récupérer l'adresse IP de notre machine ou d'une machine distante, que diriez-vous si l'on l'utilisait pour créer notre tout premier socket ? C'est parti Qu'est-ce qu'un socket ? Un socket est un point de terminaison d'une communication bidirectionnelle, c'est-à-dire entre un client et un serveur en cours d'exécution sur un réseau donné. Les deux sont liés par un même numéro de port TCP de sorte que la couche puisse identifier la demande de partage de données. Un serveur fonctionne sur une machine bien définie et est lié à un numéro de port spécifique. Le serveur se met simplement à l'écoute d'un client, qui demande une connexion. En outre, java.net comprend la classe ServerSocket, qui met en oeuvre une sorte de prise que les serveurs peuvent utiliser pour écouter et accepter les connexions des clients. Ce qui nous donne : Code : Java ServerSocket socketserver = new ServerSocket(numero_port); Ainsi on obtient un objet de la classe ServerSocket sur un port spécifique : si ce dernier est à 0, le socket est créée sur n'importe quel port libre. Il existe deux autres constructeurs ; l'un a deux paramètres, le premier est bien sûr le numéro de port et le nombre total de connexion simultanées acceptées, voyez : Code : Java ServerSocket socketserver = new ServerSocket(numer_port,nbr_max); nbr_max est le nombre maximal de connexions traitées simultanément. Par exemple au-delà de cinq tentatives de connexion consécutives autorisées, les connexions sont refusés. www.siteduzero.com
    • Introduction aux sockets 6/24 Pour le second constructeur il suffit de spécifier l'adresse locale du serveur. Code : Java ServerSocket socketserver = new ServerSocket(numer_port,nbr_max,adresse_locale); Quant au client, celui-ci connaît le nom de la machine sur laquelle le serveur est en exécution et le numéro de port sur lequel il écoute. Le client va demander une connexion au serveur en s'identifiant avec son adresse IP ainsi que le numéro de port qui lui est lié. Pour cela, le package java.net fournit une classe Socket qui met en œuvre une connexion bidirectionnelle entre votre programme Java et un autre programme situé sur le réseau. La classe Socket permet de cacher les détails d'implémentation de cette connexion. En utilisant cette classe en lieu et place d'un code natif, vos programmes peuvent communiquer sur le réseau quel que soit la plateforme sur laquelle ils se trouvent. La création d'un socket pour un programme client s'effectue à l'aide d'un des constructeurs suivants : Code : Java Socket socket = new Socket(param1, param2) Le premier paramètre correspond à l'identité du client, il peut être une chaine de caractère ou de type InetAddress, param2 correspond au numéro de port sur lequel on souhaite se connecter sur le serveur. Il est possible également de spécifier son adresse local comme troisième paramètre et le numéro de port local : Code : Java Socket socket = new Socket(adresse_distante, port_distant, adresse_locale, port_locale) Après tentative de connexion, si tout va bien, le serveur accepte la connexion du client, et reçoit un nouveau socket qui est directement lié au même port local. Il a besoin d'une nouvelle prise de sorte qu'elle puisse continuer à écouter le socket d'origine pour les demandes de connexion, tout t'en satisfaisant les besoins du client connecté. V comment accepter une connexion oici d'un client : Code : Java Socket socketduserveur = socketserver.accept(); Une fois le socket créé, l'attente de connexion provenant du client se fait à l'aide de la méthode accept(). La méthode accept() reste bloquante tant qu'elle n'a pas détecté de connexion. Afin d'éviter une attente infinie, il est possible de spécifier un délai maximal d'attente à l'aide d'un mutateur setSoTimeout. Si un timeout est une valeur strictement positive, l'appel accept() va générer une attente maximale égale à timeout. Si ce temps expire, une exception de type InterruptedIOException est levée sans toute fois que la socket de type ServerSocket ne soit invalidée. La lecture de ce timeout se fait à l'aide de l'accesseur getSoTimeout(). Côté client, si la connexion est acceptée, une socket est créé et le client peut utiliser la socket pour communiquer avec le serveur. www.siteduzero.com
    • Introduction aux sockets 7/24 L'établissement d'une connexion peut lever une exception de type IOException. On va essayer d'établir une communication. V ous avez tout les éléments à portée de main, vous pouvez désormais établir une connexion, au boulot ! ...Ce n'était pas si difficile que ça, voyons la correction Le client et le serveur peuvent à présent communiquer par l'écriture ou la lecture de leurs prises. Secret (cliquez pour afficher) Serveur.java Code : Java import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; public class Serveur { public static void main(String[] zero) { ServerSocket socketserver Socket socketduserveur ; ; try { socketserver = new ServerSocket(2009); socketduserveur = socketserver.accept(); System.out.println("Un zéro s'est connecté !"); socketserver.close(); socketduserveur.close(); } }catch (IOException e) { e.printStackTrace(); } } Client.java Code : Java import import import import java.io.IOException; java.net.InetAddress; java.net.Socket; java.net.UnknownHostException; public class Client { public static void main(String[] zero) { Socket socket; try { socket = new Socket(InetAddress.getLocalHost(),2009); socket.close(); }catch (UnknownHostException e) { www.siteduzero.com
    • Introduction aux sockets 8/24 e.printStackTrace(); }catch (IOException e) { } } e.printStackTrace(); } Lancez le serveur en premier et ensuite le client ! V ous venez d'établir votre première connexion entre un serveur et un client . Maintenant, voyons comment envoyer et recevoir des messages. Attention : il ne faut jamais oublier de fermer le socket ! Sinon si vous utilisez le même port dans un autre programme, ce (l'action de fermer une socket) ne sera plus possible car il (le port) sera occupé ! Échange de message Une fois la connexion établie et les sockets en possession, il est possible de récupérer le flux d'entrée et de sortie de la connexion TCP vers le serveur. Il existe deux méthodes pour permettre la récupération des flux : getInputStream() de la classe InputStream. Elle nous permet de gérer les flux entrant ; getOutputStream() de la classe OuputStream. Elle nous permet de gérer les flux sortant. Ces deux méthodes nous permettent donc de gérer les flux en entrée et en sortie. En général le type d'entrée et sortie utilisé est BufferedReader et InputStreamReader pour la lecture, PrintWriter pour l'écriture. Mais on peut utiliser tous les autres flux. En se basant sur l'annexe du tuto Java : BufferedReader : cette classe permet de lire des caractères à partir d'un flux tamponné, afin de faire des lectures plus rapides ; InputStreamReader : convertit un flux binaire en flux de caractères : elle convertit un objet de type InputStream en objet de type Reader ; PrintWriter : la classe PrintWriter ajoute à un flux la possibilité de faire des écritures sous forme de texte des types primitifs Java, et des chaînes de caractères. Un petit exemple de communication en image et en code source : www.siteduzero.com
    • Introduction aux sockets 9/24 Serveur.java Code : Java import import import import import import import import import java.io.BufferedReader; java.io.IOException; java.io.InputStreamReader; java.io.PrintWriter; java.net.InetAddress; java.net.ServerSocket; java.net.Socket; java.net.UnknownHostException; java.io.PrintWriter; public class Serveur { public static void main(String[] zero) { ServerSocket socketserver Socket socketduserveur ; BufferedReader in; PrintWriter out; ; try { socketserver = new ServerSocket(2009); System.out.println("Le serveur est à l'écoute du port "+socketserver.getLocalPort()); socketduserveur = socketserver.accept(); System.out.println("Un zéro s'est connecté"); out = new PrintWriter(socketduserveur.getOutputStream()); out.println("Vous êtes connecté zéro !"); out.flush(); socketduserveur.close(); socketserver.close(); }catch (IOException e) { www.siteduzero.com
    • Introduction aux sockets } } 10/24 e.printStackTrace(); } Client.java Code : Java import import import import import import import java.io.BufferedReader; java.io.IOException; java.io.InputStreamReader; java.io.PrintWriter; java.net.InetAddress; java.net.Socket; java.net.UnknownHostException; public class Client { public static void main(String[] zero) { Socket socket; BufferedReader in; PrintWriter out; try { socket = new Socket(InetAddress.getLocalHost(),2009); System.out.println("Demande de connexion"); in = new BufferedReader (new InputStreamReader (socket.getInputStream())); String message_distant = in.readLine(); System.out.println(message_distant); socket.close(); }catch (UnknownHostException e) { e.printStackTrace(); }catch (IOException e) { } } e.printStackTrace(); } Résultat chez le serveur : Code : Console Le serveur est à l'écoute du port 2009 Un zéro s'est connecté Résultat chez le client : www.siteduzero.com
    • Introduction aux sockets 11/24 Code : Console Demande de connexion Vous êtes connecté zéro ! Ho là ! Un instant ! C'est quoi, ces encapsulations et ce flush ? Rassurez-vous, on va tout expliquer en détail ( ), surtout ne vous affolez pas. Côté Serveur Après établissement de la connexion, le serveur obtient son socket qu'il utilise pour gérer le flux sortant à l'aide de socketduserveur.getOutputStream() ; ensuite, à l'aide de la méthode println on envoie un message au client, on utilise flush pour vider le buffer tout simplement. Et pour finir on ferme la connexion. Côté Client Après avoir obtenu notre socket, on utilise socket.getInputStream() pour récupérer le flux sortant. La méthode readLine() nous permet de lire une chaîne de caractères. Il existe plusieurs autres méthodes telles : readInt() permettant de lire un entier ; readDouble() permettant de lire un nombre de type double ; … Pour finir, on affiche le message reçu et on ferme notre socket. Ça a l'air très simple à première vue pour deux hôtes, mais si l'on veut que plus que deux puissent communiquer entre eux à la fois, comment faire ? D'où la nécessité d'utiliser les Threads. Utilisation des threads Je pars du principe que vous connaissez ce que sont les threads et comment les utiliser et pourquoi doit-on les utiliser dans nos programme, on va donc attaquer directement la pratique. Le principe d'utilisation des Threads est simple (sera simple si vous suivez attentivement :D). Après avoir créer un objet ServerSocket par le serveur, on le place (l'objet) comme paramètre à un constructeur de la classe qui implémente la classe Runnable ou étend la classe Thread , dès qu'un client souhaite se connecter avec le serveur, un Thread s'occupe de la connexion, il ne sera plus la peine de faire appel au serveur lorsqu'un client souhaite se connecter, tout le boulot sera confié à un Thread. V ous commencez à comprendre l'utilité des Threads avec le temps vous ne pourrez plus vous en passer. V oyons un petit exemple de connexion Multi-Threads en image et avec un code source toujours : www.siteduzero.com
    • Introduction aux sockets 12/24 Serveur.java Code : Java import java.io.IOException; import java.net.*; public class Serveur { public static void main(String[] zero){ ServerSocket socket; try { socket = new ServerSocket(2009); Thread t = new Thread(new Accepter_clients(socket)); t.start(); System.out.println("Mes employeurs sont prêts !"); } catch (IOException e) { } } } e.printStackTrace(); class Accepter_clients implements Runnable { private ServerSocket socketserver; private Socket socket; private int nbrclient = 1; public Accepter_clients(ServerSocket s){ socketserver = s; } public void run() { try { while(true){ socket = socketserver.accept(); // Un client se connecte on l'accepte System.out.println("Le client numéro "+nbrclient+ " est connecté !"); nbrclient++; socket.close(); } } catch (IOException e) { e.printStackTrace(); www.siteduzero.com
    • Introduction aux sockets } 13/24 } } Client.java Code : Java import java.io.IOException; import java.net.*; public class Client { public static void main(String[] zero){ Socket socket; try { socket = new Socket("localhost",2009); socket.close(); } catch (IOException e) { } } } e.printStackTrace(); Résulats : Code : Console Mes employeurs sont prêts ! Le client numero 1 est connecté ! Le client numero 2 est connecté ! Le client numero 3 est connecté ! Si vous m'avez bien suivis vous ne devriez pas avoir du mal à comprendre ce code. Dès que quelqu'un tape à la porte, on demande à un employer de lui ouvrir la porte, celui-là va le saluer et lui dire bye bye avec socket.close(); s'il ne veut pas parler (communiquer) . TP : un mini-chat entre le client et le serveur ! À présent que nous savons su manier les sockets en utilisant les threads, réalisons un petit programme client / serveur : après la connexion du client, celui-ci devra s'authentifier en premier, le serveur va vérifier dans un fichier la validité de ses données ; si tout est O.K., un message lui dira qu'il est connecté, ils pourront ensuite envoyer tous leurs messages au serveur. V : très oilà simple. On devra avoir quelque chose de ce genre côté serveur, pour plusieurs clients à la fois : Code : Console Le serveur est à l'écoute du port 2009 Un zéro veut se connecter softdeath vient de se connecter softdeath : salut, M. le serveur, j'ai besoin de vos services. www.siteduzero.com
    • Introduction aux sockets 14/24 Un zéro veut se connecter chabanus vient de se connecte chabanus : salut, j'ai besoin d'accéder à telles données. et du côté du client, tête-à-tête avec le serveur après connexion : Code : Console Demande de connexion Connexion établie avec le serveur, authentification : Entrez votre login : chabanus Entrez votre mot de passe : chabanus Je suis connecté Votre message : salut Le serveur vous dit : salut Votre message : ça va ? Le serveur vous dit : bien et toi ? Allez au boulot ! … … … … J'espère que vous avez au moins essayé. Cette solution n'est ni unique ni la meilleure, elle est simple et minimale pour vous montrer comment les threads doivent être gérés. V oyons la correction : Côté Serveur Secret (cliquez pour afficher) Accepter_connexion.java Code : Java import java.io.*; import java.net.*; public class Accepter_connexion implements Runnable{ private ServerSocket socketserver = null; private Socket socket = null; public Thread t1; public Accepter_connexion(ServerSocket ss){ socketserver = ss; } public void run() { try { while(true){ socket = socketserver.accept(); System.out.println("Un zéro veut se connecter "); www.siteduzero.com
    • Introduction aux sockets 15/24 t1 = new Thread(new Authentification(socket)); t1.start(); } } catch (IOException e) { } } System.err.println("Erreur serveur"); } Authentification .java Code : Java import import import import java.net.*; java.util.NoSuchElementException; java.util.Scanner; java.io.*; public class Authentification implements Runnable { private Socket socket; private PrintWriter out = null; private BufferedReader in = null; private String login = "zero", pass = public boolean authentifier = false; public Thread t2; null; public Authentification(Socket s){ socket = s; } public void run() { try { in = new BufferedReader(new InputStreamReader(socket.getInputStream())); out = new PrintWriter(socket.getOutputStream()); while(!authentifier){ out.println("Entrez votre login :"); out.flush(); login = in.readLine(); out.println("Entrez votre mot de passe :"); out.flush(); pass = in.readLine(); if(isValid(login, pass)){ out.println("connecte"); System.out.println(login +" vient de se connecter "); out.flush(); authentifier = true; } else {out.println("erreur"); out.flush();} } t2 = new Thread(new Chat_ClientServeur(socket,login)); t2.start(); } catch (IOException e) { } System.err.println(login+" ne répond pas !"); www.siteduzero.com
    • Introduction aux sockets } 16/24 } private static boolean isValid(String login, String pass) { boolean connexion = false; try { Scanner sc = new Scanner(new File("zero.txt")); while(sc.hasNext()){ if(sc.nextLine().equals(login+" "+pass)){ connexion=true; break; } } } catch (FileNotFoundException e) { System.err.println("Le fichier n'existe pas !"); } return connexion; } } Chat_ClientServeur.java Code : Java import import import import import java.io.BufferedReader; java.io.IOException; java.io.InputStreamReader; java.io.PrintWriter; java.net.Socket; public class Chat_ClientServeur implements Runnable { private private private private private Socket socket = null; BufferedReader in = null; PrintWriter out = null; String login = "zero"; Thread t3, t4; public Chat_ClientServeur(Socket s, String log){ socket = s; login = log; } public void run() { try { in = new BufferedReader(new InputStreamReader(socket.getInputStream())); out = new PrintWriter(socket.getOutputStream()); Thread t3 = new Thread(new Reception(in,login)); t3.start(); Thread t4 = new Thread(new Emission(out)); t4.start(); } } } catch (IOException e) { System.err.println(login +"s'est déconnecté "); } www.siteduzero.com
    • Introduction aux sockets 17/24 Emission .java Code : Java import java.io.IOException; import java.io.PrintWriter; import java.util.Scanner; public class Emission implements Runnable { private PrintWriter out; private String message = null; private Scanner sc = null; public Emission(PrintWriter out) { this.out = out; } public void run() { sc = new Scanner(System.in); } while(true){ System.out.println("Votre message :"); message = sc.nextLine(); out.println(message); out.flush(); } } Reception.java Code : Java import java.io.BufferedReader; import java.io.IOException; public class Reception implements Runnable { private BufferedReader in; private String message = null, login = null; public Reception(BufferedReader in, String login){ } this.in = in; this.login = login; public void run() { while(true){ try { message = in.readLine(); System.out.println(login+" : "+message); } catch (IOException e) { } } } e.printStackTrace(); www.siteduzero.com
    • Introduction aux sockets 18/24 } Serveur.java Code : Java import java.io.*; import java.net.*; public class Serveur { public static ServerSocket ss = null; public static Thread t; public static void main(String[] args) { try { ss = new ServerSocket(2009); System.out.println("Le serveur est à l'écoute du port "+ss.getLocalPort()); t = new Thread(new Accepter_connexion(ss)); t.start(); } catch (IOException e) { System.err.println("Le port "+ss.getLocalPort()+" est déjà utilisé !"); } } } Côté Client Secret (cliquez pour afficher) Chat_ClientServeur.java Code : Java import java.io.*; import java.net.*; import java.util.Scanner; public class Chat_ClientServeur implements Runnable { private private private private private Socket socket; PrintWriter out = null; BufferedReader in = null; Scanner sc; Thread t3, t4; public Chat_ClientServeur(Socket s){ socket = s; } public void run() { try { www.siteduzero.com
    • Introduction aux sockets 19/24 out = new PrintWriter(socket.getOutputStream()); in = new BufferedReader(new InputStreamReader(socket.getInputStream())); sc = new Scanner(System.in); Thread t4 = new Thread(new Emission(out)); t4.start(); Thread t3 = new Thread(new Reception(in)); t3.start(); } } catch (IOException e) { System.err.println("Le serveur distant s'est déconnecté !"); } } Client.java Code : Java import java.io.*; import java.net.*; public class Client { public static Socket socket = null; public static Thread t1; public static void main(String[] args) { try { System.out.println("Demande de connexion"); socket = new Socket("127.0.0.1",2009); System.out.println("Connexion établie avec le serveur, authentification :"); // Si le message s'affiche c'est que je suis connecté t1 = new Thread(new Connexion(socket)); t1.start(); } catch (UnknownHostException e) { System.err.println("Impossible de se connecter à l'adresse "+socket.getLocalAddress()); } catch (IOException e) { System.err.println("Aucun serveur à l'écoute du port "+socket.getLocalPort()); } } } Connexion.java Code : Java www.siteduzero.com
    • Introduction aux sockets 20/24 import java.net.*; import java.util.Scanner; import java.io.*; public class Connexion implements Runnable { private Socket socket = null; public static Thread t2; public static String login = null, pass = null, message1 = null, message2 = null, message3 = null; private PrintWriter out = null; private BufferedReader in = null; private Scanner sc = null; private boolean connect = false; public Connexion(Socket s){ } socket = s; public void run() { try { out = new PrintWriter(socket.getOutputStream()); in = new BufferedReader(new InputStreamReader(socket.getInputStream())); sc = new Scanner(System.in); while(!connect ){ System.out.println(in.readLine()); login = sc.nextLine(); out.println(login); out.flush(); System.out.println(in.readLine()); pass = sc.nextLine(); out.println(pass); out.flush(); if(in.readLine().equals("connecte")){ System.out.println("Je suis connecté "); connect = true; } else { System.err.println("Vos informations sont incorrectes "); } } t2 = new Thread(new Chat_ClientServeur(socket)); t2.start(); } catch (IOException e) { } } System.err.println("Le serveur ne répond plus "); } Emission.java Code : Java www.siteduzero.com
    • Introduction aux sockets 21/24 import java.io.IOException; import java.io.PrintWriter; import java.util.Scanner; public class Emission implements Runnable { private PrintWriter out; private String login = null, message = null; private Scanner sc = null; public Emission(PrintWriter out) { this.out = out; } public void run() { sc = new Scanner(System.in); } while(true){ System.out.println("Votre message :"); message = sc.nextLine(); out.println(message); out.flush(); } } Reception.java Code : Java import java.io.BufferedReader; import java.io.IOException; public class Reception implements Runnable { private BufferedReader in; private String message = null; public Reception(BufferedReader in){ } this.in = in; public void run() { while(true){ try { message = in.readLine(); System.out.println("Le serveur vous dit :" +message); } catch (IOException e) { } } } e.printStackTrace(); } www.siteduzero.com
    • Introduction aux sockets 22/24 Lancez serveur.java et ensuite client.java, n'oubliez pas de créer un fichier pour le serveur pour qu'il puisse y vérifier l'identité de ses clients, je l'ai nommé zero.txt : vous pouvez le nommer comme vous le souhaitez, c'est à votre guise. Optimisation : Pour ne pas dire qu'il en existe à l'infini, plusieurs autres possibilités s'offrent à vous, vous pouvez : rendre l'application client / client. Le serveur authentifie les deux clients et ces deux-là pourront discuter ensemble sans que d'autres puissent y entrer : grosso modo réaliser un « salon », comme on l'appelle ; utiliser les bases de données pour la sauvegarde des messages et pour authentifier les clients ; réaliser une interface graphique en swing ou en awt ; … Croyez-moi : lorsque vous maîtriserez les sockets en utilisant les threads, rien ne sera plus compliqué pour vous. continuation à tous ; surtout n'hésitez pas à l'améliorer et envoyez-moi un MP pour m'exposer votre travail. Bonne Q.C.M. Le premier QCM de ce cours vous est offert en libre accès. Pour accéder aux suivants Connectez-vous Inscrivez-vous Quelle est la classe qui permet de créer un socket pour le serveur ? SocketServer. ServeurSocket. SocketServeur. ServerSocket. Un client peut créer plusieurs sockets. Vrai. Faux. Qu'est-ce qui cloche dans ce code ? Code : Java try { ServerSocket ss= new ServerSocket(1026); ss.close(); Socket s = ss.accept(); } catch (IOException e) { } On a oublié d'utiliser les threads. On doit d'abord instancier un objet Socket avant ServerSocket. On a coupé l'écoute du serveur avant d'accepter les clients. On devrait mettre 2009 à la place de 1026. Le port 1026 est un port réservé. Correction ! Statistiques de réponses au Q CM Le mode UDP est plus rapide que le mode TCP mais c'est une communication non fiable, car on ne se préoccupe pas du résultat de la réception du récepteur, il est donc moins utilisé. Maintenant que vous savez manier les sockets, le mode UDP ne devrait pas vous poser de problème . www.siteduzero.com
    • Introduction aux sockets 23/24 Je vous remercie d'avoir lu le tutoriel, il est à présent terminé. J'espère que vous avez bien suivi À la prochaine pour un autre tutoriel client/serveur ! La technologie RMI (Remote Method Invocation) ! Qui vous permettra de mieux comprendre la nature et la fonction des EJB (Entreprise JavaBeans) qui représente l'étendard de la plate-forme J2EE ! Je remercie : Le membre cysboy pour m'avoir encouragé. Les validateurs Xavinou, Coyote et Thunderseb. Le zCorrecteur Poulpette pour avoir pris le temps de corriger le tutoriel. Enfin, tout le staff du site du zéro qui nous permet de rédiger des tutoriels pour débutants. Partager Ce tutoriel a été corrigé par les zCorrecteurs. www.siteduzero.com