Pour plus de détails concernant le protocole TCP conférez vous à la présentation des protocoles Internet enseignée pendant.



Documents pareils
Programmation Internet en Java

Le modèle client-serveur

Communication inter-processus (IPC) : tubes & sockets. exemples en C et en Java. F. Butelle

Flux de données Lecture/Ecriture Fichiers

Gestion distribuée (par sockets) de banque en Java

Programmation client-serveur sockets - RPC

Cours 6 : Programmation répartie

Cahier des Charges du Projet Domotique. Choquet Mathieu Masson Jérôme Groupe 6. Domotique. p.1

Dis papa, c est quoi un bus logiciel réparti?

Programmation Réseau SSH et TLS (aka SSL)

Introduction à HTTP. Chapitre HTTP 0.9

Programmer en JAVA. par Tama

Auto-évaluation Programmation en Java

Synchro et Threads Java TM

PROGRAMMATION PAR OBJETS

HTTP 1.1. HyperText Transfer Protocol TCP IP ...

Projet de programmation (IK3) : TP n 1 Correction

Introduction : les processus. Introduction : les threads. Plan

(structure des entêtes)

Un ordonnanceur stupide

RMI le langage Java XII-1 JMF

Principes des Architectures Middleware version 2.0

TP3. Mail. Attention aux fausses manoeuvres lors de ce TP vous pouvez endommager votre mail sur ouindose.

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

TP Composants Java ME - Java EE. Le serveur GereCompteBancaireServlet

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Corrigé des exercices sur les références

Android UIThread, Thread, Handler et AsyncTask

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

STS SE. FreeRTOS. Programmation réseau WIFI. Programmation réseau. Socket Tcp. FlyPort smart Wi-Fi module

Remote Method Invocation Les classes implémentant Serializable

Remote Method Invocation (RMI)

Calcul Parallèle. Cours 5 - JAVA RMI

Programmation Orientée Objet - Licence TIS CM8/9. Rappel sur la séance précédente. Lancelot Pecquet Lancelot.Pecquet@math.univ-poitiers.

Java Licence Professionnelle CISII,

RMI. Remote Method Invocation: permet d'invoquer des méthodes d'objets distants.

Desktop Intégration. Rémi Forax

L3 informatique TP n o 2 : Les applications réseau

Accéder à PostgreSQL par JDBC via un tunnel SSL Java

PIGOURIER Vincent ANNEE SPECIALE 99/00 RAPPORT DE PROJET : LES THREADS JAVA. Responsable : Serge Rouveyrol

et se trouve popularisé rapidement pour ses possibilités de développement liés au Web. Les

Développement Logiciel

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

M1 MIAGE - Réseau TP1

Serveurs de noms Protocoles HTTP et FTP

Java Licence Professionnelle Cours 7 : Classes et méthodes abstraites

Programmation Réseau. Sécurité Java. UFR Informatique jeudi 4 avril 13

Cours 1: Java et les objets

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Programmation Par Objets

Cette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :

Entrées / Sorties. Entrées / Sorties. Entrées/Sorties. System.out. Fonctionnement par flots (stream) Karima Boudaoud IUT- R&T. Terrain connu.

LMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr

Une introduction à la technologie EJB (2/3)

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

Internet. Web Sécurité Optimisation

ALGORITHMIQUE ET PROGRAMMATION ORIENTEE OBJET

Threads. Threads. USTL routier 1

Introduction au langage Java

Premiers Pas en Programmation Objet : les Classes et les Objets

INITIATION AU LANGAGE JAVA

Développement d un logiciel de messagerie instantanée avec Dotnet (version simplifiée)

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Chapitre 10. Les interfaces Comparable et Comparator 1

Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour

ACTIVITÉ DE PROGRAMMATION

Modèle à composants. Daniel Hagimont. IRIT/ENSEEIHT 2 rue Charles Camichel - BP TOULOUSE CEDEX 7. Remerciements

La base de données XML exist. A. Belaïd

Java DataBaseConnectivity

Le Modèle de Sécurité dans JAVA

Plan du cours. Historique du langage Nouveautés de Java 7

Info0101 Intro. à l'algorithmique et à la programmation. Cours 3. Le langage Java

Package Java.util Classe générique

TP, première séquence d exercices.

JAVA. Introduction à la programmation objet avec java 1/4. Nadir BOUSSOUKAIA

Web Tier : déploiement de servlets

Une introduction à Java

J2SE Threads, 1ère partie Principe Cycle de vie Création Synchronisation

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting

Java Licence Professionnelle CISII,

Info0604 Programmation multi-threadée. Cours 5. Programmation multi-threadée en Java

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

Le MSMQ. Version 1.0. Pierre-Franck Chauvet

PHP et mysql. Code: php_mysql. Olivier Clavel - Daniel K. Schneider - Patrick Jermann - Vivian Synteta Version: 0.9 (modifié le 13/3/01 par VS)

Lier Erlang avec d autres langages de programmation

TD3: tableaux avancées, première classe et chaînes

LA COUCHE TRANSPORT CONTRÔLE LE FLOT DE DONNEES TRANSMISES par la couche Réseau

Cours 14 Les fichiers

Application Web et J2EE

Langage à objets : JAVA (1)

as Architecture des Systèmes d Information

INF8007 Langages de script

API04 Contribution. Apache Hadoop: Présentation et application dans le domaine des Data Warehouses. Introduction. Architecture

Utilisation d objets : String et ArrayList

Licence Bio Informatique Année Premiers pas. Exercice 1 Hello World parce qu il faut bien commencer par quelque chose...

Module http MMS AllMySMS.com Manuel d intégration

Classe ClInfoCGI. Fonctions membres principales. Gestion des erreurs

Programmation système I Les entrées/sorties

A DESTINATION DES SERVICES TIERS. Editeurs d applications et ressources pédagogiques connectées à l ENT

Solutions du chapitre 4

Transcription:

Chapitre 7 Le mode de communication en connexion est, a priori, supporté par le protocole TCP. Ce protocole fournit une communication fiable; les données sont transmises comme chaînes d octets. Avant de pouvoir effectuer un transfert, une connexion doit être établie entre les postes communicants. En principe, le poste client demande une connexion au serveur; le serveur accepte ou rejette cette demande. Si la demande est acceptée, un canal de communication est établi. Pour plus de détails concernant le protocole TCP conférez vous à la présentation des protocoles Internet enseignée pendant. En Java le packagejava.net.* contient toutes les classes nécessaires pour le développement des applications fonctionnant en mode connecté. Socket client Le socket client en mode connecté est créé par le constructeur Socket. Ce constructeur attache le socket par défaut à une adresse locale et à un port local disponible, et initialise la demande de connexion à un poste distant. String host = oak ; int port=7; Socket s = new Socket(host,port); String host = oak ; InetAddress ia=inetaddress.getbyname(host); int port=7; Socket s = new Socket(ia,port); Exemple: Socket(oak,7) Client Serveur Socket(host,port) L exemple suivant montre une application avec un socket client essayant de se connecter sur différents services sur le hôte demandé (args[0]). L exemple suivant montre une application avec un socket client essayant de se connecter sur différents services sur le hôte demandé (args[0]). import java.net.*; import java.io.*; host,port

public class PortScanner { public static void main(string[] args) { String host = "localhost"; // hote par defaut if(args.length>1) host= args[0]; InetAddress adresse = InetAddress.getByName(host); for(int i=1; i<5000; i++) { try { Socket s = new Socket(adresse,i); System.out.println("Host: " + host + " un service sur le port: " + i); s.close(); catch(ioexception e){ System.err.println(e); catch(unknownhostexception e) {System.err.println(e); Attention: Les méthodes InetAddress.getByName(host) et new Socket(adresse) doivent capter respectivement l exception UnknownHostException et l exception IOException. Le constructeur permet de préciser l adresse et le port local à utiliser par le socket : public Socket(String remotehost, int remoteport, InetAddress localinterface, int localport); Les deux premiers arguments sont les mêmes que dans l exemple ci-dessus; les arguments localinterface et localport déterminent le socket local. Méthodes get Les méthodes de type get appliquées à un socket permettent d extraire les quatre arguments utilisés par le constructeur ci-dessus, c est-à-dire: remotehost, remoteport, LocalInterface, localport. Socket s = new Socket( ireste.fr,80); InetAddress remotehost = s.getinetaddress(); int remoteport = s.getport(); InetAddress localinterface= s.getlocaladdress(); int localport= g.getlocalport();

Lecture et écriture dans le socket client Les méthodes getinputstream() et getoutputstream() permettent de lire et d écrire dans les streams de données associés à un socket. Habituellement, un stream simple de classe InputStream est filtré par InputStreamReader et BufferedReader. Le stream de sortie, OutputStream, est filtré par PrintWriter. L exemple suivant montre une simple application client qui envoie au serveur echo une chaîne de caractères saisie sur le clavier. Le serveur renvoie la même chaîne. import java.io.*; import java.net.*; public class ClientEchoTCP{ public static void main(string[] args) throws Exception{ Socket echosocket; PrintWriter out; BufferedReader in; echosocket = new Socket("oak", 7); out = new PrintWriter(echoSocket.getOutputStream(),true); // stream de sortie sur socket in = new BufferedReader(new InputStreamReader(echoSocket.getInputStream())); // stream d entree BufferedReader stdin = new BufferedReader( new InputStreamReader(System.in)); // stream System.in while(true) { String userinput = stdin.readline(); // saisie des donnees if(userinput.equals("end")) break; out.println(userinput); out.flush(); System.out.println(in.readLine()); // affichage des donnees out.close(); in.close(); echosocket.close(); Options de socket Les options socket spécifient comment lire et recevoir les données. Les quatre options de base sont: TCP_NODELAY SO_BINDADDR SO_TIMEOUT SO_LINGER Les données envoyées par le protocole TCP passent par les tampons de sortie et d entrée; leur temps d acheminement peut être assez long. La première option TCP_NODELAY est utilisée pour l envoi de données urgentes; par exemple, un octet signalant une interruption. Un octet urgent est envoyé dans un segment TCP sans passer par la file d attente dans les tampons.

L exemple ci-dessous de type test and set annule la bufferisation (mise en tampon) pour les octets à suivre: if(!s.gettcpnodelay()) s.settcpnodelay(true) La lecture des données par la méthode read() attend le nombre d octets spécifié dans ses arguments. Si les octets demandés n arrivent pas, le programme est bloqué. L option SO_TIMEOUT est utilisée pour débloquer la méthode read() après un laps de temps spécifié. Par exemple, le code ci-dessous, teste la valeur actuelle du timeout; si elle est égale à zéro, une valeur de 10 secondes est proposée. if(s.getsotimeout() == 0) s.setsotimeout(10000); En cas de problème à l exécution, les deux méthodes TCP_NODELAY et SO_TIMEOUT lèvent l exception SocketException. Socket serveur Le socket serveur est utilisé pour créer une application serveur. Un serveur fonctionnant en mode connecté attend une demande de connexion envoyée par le socket client. Quand cette demande est enregistrée et acceptée par le socket serveur une connexion est initialisée. En acceptant une connexion sur la méthode accept() le serveur génère un socket de communication (un socket ordinaire ) permettant d effectuer le transfert des données sur la connexion. A la fin du service le serveur ferme le socket de communication et attend la demande de connexion suivante. Il y a trois constructeurs de classe ServerSocket: public ServerSocket(int port) throws IOException, (BindException) public ServerSocket(int port, int queuelength) throws IOException, (BindException) public ServerSocket(int port,int queuelength, InetAddress bindaddress) throws IOException L argument queuelength impose la longueur de la file d attente de demandes de connexion. Cette valeur est normalement inférieure à 50. Exemples de constructeurs: ServerSocket echo = new ServerSocket(7); catch (IOException e) { System.err.println(e); ServerSocket echo = new ServerSocket(6969,40); catch (IOException e) { System.err.println(e); Le serveur fonctionne dans un cycle et accepte des connexions à tour de rôle. Après l acceptation d une demande de connexion, la méthode accept() renvoie un objet Socket à utiliser dans la communication. A la fin du cycle le serveur doit fermer le socket de communication par la méthode close(). Exemple d un cycle:

ServerSocket serveur = new ServerSocket(6969); while(true) { Socket connexion = serveur.accept(); OutputStreamWriter out = new OutputStreamWriter(connexion.getOutputStream()); out.write( la connexion est établie ); // ici ecrire la fonction du serveur connexion.close(); Attention: La méthode accept() est bloquante. Afin de pouvoir débloquer une attente sur accept() il faut lancer la méthode setsotimeout(). Un entier passé en argument détermine le délai maximal d attente exprimé en millisecondes. ServerSocket serveur = new ServerSocket(6969,10); serveur.setsotimeout(3000); Socket s = serveur.accept(); // attente bloquee sur 3 secondes au maximum L exemple suivant devient plus complet et robuste grâce à l ajout de fonctions de test déterminées par les instructions try et catch. ServerSocket serveur = new ServerSocket (6969); while(true) { Socket connexion = serveur.accept(); OutputStreamWriter out = new OutputStreamWriter(connexion.getOutputStream()); out.write( la connexion est établie ); // ici ecrire la fonction du serveur connexion.close(); catch(ioexception e) { // erreur sur cette connexion finally { if(connexion!= null) connexion.close(); // forcer la connexion si une erreur est survenue catch(ioexception e) { catch(ioexception e) {System.err.println(e); // erreur sur la creation du socket serveur L exemple ci-dessous est un simple serveur echo; il fonctionne en mode connecté et est activé sur le port numéro 7. Il permet de lire et d écrire les chaînes de caractères - String. import java.io.*; import java.net.*; public class ServerEchoTCP{ public final static int echoport = 7; public static void main(string[] args){ ServerSocket serveur= new ServerSocket(echoport);

while(true) { Socket connexion = serveur.accept(); BufferedReader in = new BufferedReader(new InputStreamReader(connexion.getInputStream())); PrintWriter out = new PrintWriter(connexion.getOutputStream(),true); String line; while ((line = in.readline())!= null) { out.println(line); // fonction echo connexion.close(); catch(ioexception e) { // erreur sur cette connexion catch(ioexception e) {System.err.println(e); // erreur sur la creation du socket serveur Services itératifs et services concurrents Dans notre exemple du serveur echo, le service est réalisé de façon itérative, c est-à-dire que les demandes des clients sont effectuées l une après l autre. Dans l exemple suivant nous présentons un serveur concurrent - inverse-echo. Dans un serveur concurrent chaque connexion est traitée séparément par un thread lancé et en parallèle avec les autres. Dans cette solution plusieurs clients peuvent être servis en parallèle sans attendre la fin des services réalisés pour les autres clients. La classe principale ServerThread prépare le socket du serveur et passe le contrôle à la méthode run(). La méthode run() boucle à l écoute des demandes de connexion et lance pour chaque connexion acceptée un nouveau thread - ConnexionThread. Ces threads exécutent de façon concurrente le même service inverse-echo. Les chaînes des caractères envoyées par client sont renvoyées dans l ordre inverse. Services itératifs et services concurrents Dans notre exemple du serveur echo, le service est réalisé de façon itérative, c est-à-dire que les demandes des clients sont effectuées l une après l autre. Dans l exemple suivant nous présentons un serveur concurrent - inverse-echo. Dans un serveur concurrent chaque connexion est traitée séparément par un thread lancé et en parallèle avec les autres. Dans cette solution plusieurs clients peuvent être servis en parallèle sans attendre la fin des services réalisés pour les autres clients. Services itératifs et services concurrents

Dans notre exemple du serveur echo, le service est réalisé de façon itérative, c est-à-dire que les demandes des clients sont effectuées l une après l autre. Dans l exemple suivant nous présentons un serveur concurrent - inverse-echo. Dans un serveur concurrent chaque connexion est traitée séparément par un thread lancé et en parallèle avec les autres. Dans cette solution plusieurs clients peuvent être servis en parallèle sans attendre la fin des services réalisés pour les autres clients. Client 1 Socket(host,port) Client 2 Socket(host,port) Client n Socket(host,port) Serveur ServerSocket ss = new ServerSocket(port); Socket cs = ss.accept(); new Thread Socket cs = ss.accept(); new Thread Socket cs = ss.accept(); new Thread La classe principale ServerThread prépare le socket du serveur et passe le contrôle à la méthode run(). La méthode run() boucle à l écoute des demandes de connexion et lance pour chaque connexion acceptée un nouveau thread - ConnexionThread. Ces threads exécutent de façon concurrente le même service inverse-echo. Les chaînes des caractères envoyées par client sont renvoyées dans l ordre inverse.la classe principale ServerThread prépare le socket du serveur et passe le contrôle à la méthode run(). La méthode run() boucle à l écoute des demandes de connexion et lance pour chaque connexion acceptée un nouveau thread - ConnexionThread. Ces threads exécutent de façon concurrente le même service inverse-echo. Les chaînes des caractères envoyées par client sont renvoyées dans l ordre inverse. import java.net.*; import java.io.*; public class ServerThread extends Thread{ public final static int defport=6969; protected int port; protected ServerSocket serveur; public static void probleme(exception e, String msg) { System.err.println("probleme: " + msg + "" + e); System.exit(1); public ServerThread(int port) { if(port==0) port=defport; serveur = new ServerSocket(port); catch(ioexception e) { probleme(e,"creation du socket serveur"); System.out.println("Serveur en ecoute sur le port: " + port);

this.start(); public void run() { while(true) { // creation des threads de Connexion Socket connexion = serveur.accept(); ConnexionThread ct = new ConnexionThread(connexion); // services en parallele catch(ioexception e) {probleme(e,"sur connexion"); public static void main(string[] args) { int port = 0; if(args.length ==1) port = Integer.parseInt(args[0]); else port = 0; new ServerThread(port); // instantiation du thread principal class ConnexionThread extends Thread { // le thread de service protected Socket client; protected BufferedReader in; protected PrintWriter out; public ConnexionThread(Socket connexion) { Socket client = connexion; in = new BufferedReader(new InputStreamReader(client.getInputStream())); out = new PrintWriter(client.getOutputStream(),true); catch(ioexception e) { client.close(); catch (IOException f) {; System.out.println("Probleme sur socket streams"); return; this.start(); public void run() { String ligne; StringBuffer revligne; int taille; try { while(true) { ligne = in.readline(); if(ligne == null) break; taille = ligne.length();

revligne = new StringBuffer(taille); for(int i=taille-1; i>=0;i--) revligne.insert(taille-1-i,ligne.charat(i)); out.println(revligne); catch(ioexception e) {; client.close(); catch(ioexception f){; Simple serveur HTTP (itératif) Les applications fonctionnant en mode connecté à la base du protocole TCP offrent des services robustes qui peuvent s étaler sur l ensemble du système Internet. Le mode connecté est exploité pour le transfert des pages html qui est de loin le service le plus répandu dans le monde Internet. Ci-dessous, avant aborder les classes Java préparées spécialement pour l utilisation directe du protocole HTTP, nous allons développer un serveur HTTP très simple. Ce serveur envoie toujours le même fichier. Le nom du fichier doit être proposé comme argument au lancement du serveur. Client - navigateur WEB (protocole HTTP) Socket(host,80) Serveur message HTTP (en-tête + contenu) ServerSocket ss = new ServerSocket(port); Socket cs = ss.accept(); InputStream in = new FileInputStream(args[0]) fichier import java.net.*; import java.io.*; import java.util.*; public class ServerSimpleHTTP extends Thread{ private byte[] contenu; private byte[] entete; private int port = 80; public static void probleme(exception e, String msg) {

System.err.println("probleme: " + msg + "" + e); System.exit(1); public ServerSimpleHTTP(String data, String encoding, String MIMEType,int port) throws UnsupportedEncodingException { this(data.getbytes(encoding), encoding, MIMEType,port); public ServerSimpleHTTP(byte[] data, String encoding, String MIMEType,int port) throws UnsupportedEncodingException { this.contenu = data; this.port = port; String entete = "HTTP 1.0 200 OK\r\n" // preparation de l en-tete http + "Server: UnFichier 1.0\r\n" + "Content-length: " + this.contenu.length + "\r\n" + "Content-type: " + MIMEType + "\r\n\r\n"; this.entete = entete.getbytes("ascii"); // conversion de l en-tete en octets public void run() { ServerSocket serveur = new ServerSocket(this.port); // creation du socket serveur System.out.println("une connexion acceptee sur port: " + serveur.getlocalport()); System.out.println("donnees a envoyer: "); System.out.write(this.contenu); while(true) { Socket connexion=null; connexion = serveur.accept(); // acceptation d une connexion OutputStream out = new BufferedOutputStream(connexion.getOutputStream()); InputStream in = new BufferedInputStream(connexion.getInputStream()); StringBuffer demande = new StringBuffer(80); while(true) { int c = in.read(); // lecture d une requete de page if(c=='\r' c=='\n' c== -1) break; demande.append((char) c); if(demande.tostring().indexof("http/")!= -1) { out.write(this.entete); // envoi de l en-tete out.write(this.contenu); // envoi du contenu out.flush(); catch (IOException e) { finally { if(connexion!= null) connexion.close(); catch(ioexception e) { probleme(e,"port occupe: ");

public static void main(string[] args) { // demarrage de l application serveur String contenutype = "text/plain"; if(args[0].endswith(".html") args[0].endswith(".htm")) { contenutype = "text/html"; InputStream in = new FileInputStream(args[0]); // ouverture du fichier a envoyer ByteArrayOutputStream out = new ByteArrayOutputStream(); int b; while ((b = in.read())!= -1) out.write(b); byte[] data = out.tobytearray(); int port; port = Integer.parseInt(args[1]); if(port<1 port>65535) port=80; // port par defaut - 80 : service http catch(exception e) { port = 80; String encoding = "ASCII"; if(args.length>=2) encoding = args[2]; Thread t = new ServerSimpleHTTP(data,encoding,contenuType,port); // creation du thread serveur t.start(); // activation du thread serveur catch(arrayindexoutofboundsexception e) { System.out.println("utilisation: java ServerSimpleHTTP nomfichier port encoding"); catch(exception e) { probleme(e,""); Le programme serveur ci-dessus peut être testé directement par le navigateur WEB. Il suffit de lancer le serveur avec un nom fichier,*.htm de préférence, et d insérer l adresse IP de l ordinateur (localhost) dans le navigateur (e.g. http://193.52.81.188). Résumé Les applications fonctionnant en mode connecté à la base du protocole TCP offrent des services robustes qui peuvent s étaler sur l ensemble du système Internet. En réalité, elles représentent la plus grosse partie de programmes développés pour l Internet. Dans le chapitre suivant nous découvrirons les classes permettant le développement des applications orientées WEB. Plus précisément, nous étudierons les classes URL de Java qui donnent la possibilité d écrire les applications en s appuyant directement sur le protocole HTTP.