Polycopié de TPs réseaux

download Polycopié de TPs réseaux

of 83

  • date post

    05-Jan-2017
  • Category

    Documents

  • view

    219
  • download

    1

Embed Size (px)

Transcript of Polycopié de TPs réseaux

  • Polycopi de TPs rseaux v.1.2

    Auteur : Adlen Ksentini Matre de Confrences lUniversit de Rennes 1.

    Tout droit rserv.

  • 2

    Prface : Ce polycopi de travaux pratiques (TP) regroupe un certain nombre dnoncs au tour des rseaux. Ces TPs ont t effectus UFR informatique et tlcommunication (ISTIC) de lUniversit de Rennes 1 (UR1) durant les six dernires annes. Le polycopi est organis par thme, et chaque thme contient un certain nombre de sujets. La premire partie introduction aux rseaux est destine des personnes nayant pas une grande connaissance dans les rseaux et voulant acqurir des notions gnrales. Les parties suivantes : routage, administration des rseaux, scurit des rseaux et VoIP, sont destin un public spcialis dans les rseaux. Ces TPs sont dans le programme du master 2 professionnels Ingnierie des rseaux (IR) de UR1. Les TPs des parties avances sont effectuer dans les conditions de la salle i207 (salle rseau de lISTIC), o chaque binme dispose de : 1 PC linux (Debian) avec 5 interfaces Ethernet, 1 PC WinXP avec 1 interface Ethernet, un routeur Cisco 1941 Series et un commutateur Cisco 2950. Chaque banc de la salle (not NB dans les TP) peut accueillir deux binmes. Je tiens remercier :

    - Gilles Guette, pour sa participation la cration des TPs Service de messagerie et Firewall , et la mise disposition de son TP authentification 802.1X.

    - Michel Le Tohic pour sa participation la cration du TP Samba. - Frdric Tronel pour sa participation la cration du TP Serveur web et scurit.

  • 3

    1re partie : Introduction au rseau

    - Analyse du protocole HTTP - Analyse des protocoles TCP et IP avec Wireshark - Interrogations dune infrastructure de rseaux Internet - Programmation rseau (Socket) en UDP - Programmation rseau (Socket) en TCP - Client/Serveur TCP : HTTP - Socket RAW : ICMP

  • 4

    Analyse du protocole

    HTTP Dure : 2h

    N.B. : Ces travaux pratiques font l'objet d'un Compte Rendu (lectronique) qui doit tre envoy avant le dbut de sance suivante l'enseignant responsable de ce TP. But: Dans ce TP nous allons explorer diffrents aspects du protocole HTTP : GET/rponse, format des messages HTTP, les fichiers HTTP volumineux, rcuprer un fichier HTML avec des objets rfrencs.

    1. Le GET et les rponses HTTP Nous allons commencer l'exploration du protocole HTTP en tlchargeant un court fichier HTML. Ce fichier ne contient pas de rfrences vers des objets.

    a) Lancez votre navigateur web b) Lancez une capture avec Wireshark. Entrez http dans l'onglet filter, pour filtrer le

    trafic HTTP. c) Attendez au moins une minute, et dmarrez la capture avec Wireshark d) Entrez l'adresse suivante dans votre navigateur web : http://anubis.istic.univ-

    rennes1.fr/TP_syr/fichier1.html. Votre navigateur doit-tre capable d'afficher la page HTML

    e) Arrtez la capture avec Wireshark

    Les deux paquets capturs

    Le c

    onte

    nu d

    u pa

    quet

    s

    lct

    ionn

    Le filtre HTTP

    En-ttes : Ethernet IP, TCP

    Votre fentre Wireshark doit ressembler la figure du dessus, o deux messages HTTP sont capturs (de votre navigateur vers le serveur anubis, et du serveur anubis vers votre navigateur). Pour rappel, le message HTTP est encapsul dans un segment TCP, qui est encapsul dans un paquet IP, qui est encapsul dans une trame Ethernet.

  • 5

    Note : Il faudrait ignorer la requte sur licne faite par votre navigateur, car ce dernier demande au serveur sil a une icne afficher. En se basant sur les informations transportes dans le GET et sa rponse, rpondez aux questions suivantes :

    a) Quelle est la version du protocole HTTP, 1.0 ou 1.1, que votre navigateur utilise ? Quelle version est utilise par le serveur ?

    b) Quels langages (si plusieurs) votre navigateur supporte ? c) Quelle est l'adresse IP de votre machine ? d) Quel est le statut (code) retourn par le serveur web la requte du navigateur ? e) Quelle est la date de la dernire modification du fichier envoy par le serveur ? f) Quelle est la taille en octets du contenu retourn vers votre navigateur ? g) Quelle la version du serveur web ?

    a) Le GET conditionnel et les rponses HTTP

    Il est important de rappeler que les navigateurs web utilisent un cache pour les objets, et ainsi des GET conditionnels sont envoys pour rcuprer un objet manquant. Assurez-vous que le cache de votre navigateur est vide (Firefox : Outils-> options->avanc->rseau cache et vider le cache. IE : tools->Internet option -> delete File). A prsent : Lancez votre navigateur, et videz votre cache

    Dmarrez une capture avec Wireshark Entrez l'adresse suivante dans votre navigateur web : http://anubis.ifsic.univ-

    rennes1.fr/TP_syr/fichier2.html. Votre navigateur affichera une page HTML simple. Entrez encore une fois l'adresse ci-dessus (ou rafraichir la page) Arrtez la capture, et filtrez le trafic http

    Rpondre aux questions suivantes : a) Inspectez le contenu de la premire requte GET de votre navigateur vers le serveur.

    Voyez-vous le la ligne IF-MODIFIED-SINCE: dans la requte ? b) Inspectez le contenu de la rponse du serveur. Est-ce que le serveur renvoie

    implicitement le contenu du fichier ? Comment pouvez-vous l'affirmer ? c) Inspectez le contenu de la deuxime requte GET de votre navigateur vers le serveur.

    Voyez-vous le la ligne IF-MODIFIED-SINCE: dans la requte ? Si oui, quelle est l'information qui suit l'en-tte IF-MODIFIED-SINCE:

    d) Quel est le statut code et la phrase retourne par le serveur en rponse du second GET ? Est-ce que le serveur renvoie implicitement le contenu du fichier ? Expliquez.

    3. Retrouver des documents HTML volumineux

    Dans nos prcdents exemples, les documents demands sont simples et assez courts. Maintenant, nous allons nous intresser aux documents HTML volumineux.

    Lancez votre navigateur web, et assurez-vous que le cache du navigateur est vide Lancez une capture avec Wireshark Entrez l'adresse suivante dans votre navigateur web : http://anubis.istic.univ-

    rennes1.fr/TP_syr/fichier3.html. Arrtez la capture, et filtrez le trafic http

    Dans la fentre principale de Wireshark, vous devez apercevoir votre message GET, suivi par plusieurs paquets rponse cette requte. Ceci ncessite une petite explication. Dans le cours nous avons vu qu'une rponse HTTP contient un statut, un en-tte suivi par une ligne vide et le corps du paquet (entity body). Dans le cas de notre GET, le corps du message rponse est la totalit de la page HTML. Du coup, ce fichier HTML est volumineux (4500 octets), et il ne peut pas tre transmis dans un seul segment TCP. Ainsi la rponse HTTP est divise en plusieurs pices par TCP, chaque pice est encapsule dans un seul segment TCP. Chaque segment TCP est enregistr sparment par

  • 6

    Wireshark, et le fait quune rponse HTTP a t divise en plusieurs segments TCP est indiqu par la phrase Continuation . Il est important de noter qu'il n'y pas de message Continuation en HTTP !. Rpondre aux questions suivantes :

    Combien de requtes GET ont t envoyes par votre navigateur ? Combien de segments TCP (transportant les donnes) sont ncessaires pour transmettre

    le message rponse HTTP ? Quel est le statut (code) et la phrase associe la rponse du GET ? Y'a-t-il des lignes dans les donnes transmis en continuation qui refltes le statut

    (code) du message HTTP ?

    a) Documents HTML avec des objets rfrencs A prsent nous allons nous intresser aux fichiers HTML qui rfrencent des objets (dans notre exemple des images) stocks sur d'autres serveurs web.

    Lancez votre navigateur web, et assurez-vous que le cache du navigateur est vide Lancez une capture avec Wireshark Entrez l'adresse suivante dans votre navigateur web : http://anubis.istic.univ-

    rennes1.fr/TP_syr/fichier4.html. Votre navigateur doit afficher une courte page HTML avec deux images. Ces deux images sont rfrences dans le code HTML. Ces deux images ne sont pas contenues dans le fichier HTML; mais uniquement leur URL est dfinis dans le code. Le logo de l'ISTIC est sur le serveur www.ifsic.univ-rennes1.fr et le logo ENT est sur le serveur www.univ-rennes1.fr

    Arrtez la capture, et filtrez le trafic http Rpondre aux questions suivantes :

    Combien de requtes GET ont t envoyes par votre navigateur ? quelles adresses IP sont-elles envoyes ?

    Pouvez-vous indiquer si votre navigateur a tlcharg les deux photos en parallle ou l'une aprs l'autre (srie) ? Expliquez.

  • 7

    Analyse des protocoles

    TCP et IP avec Wireshark Dure : 2h.

    N.B. : Ces travaux pratiques font l'objet d'un Compte Rendu (lectronique) qui doit tre envoy avant le dbut de sance suivante l'enseignant responsable de ce TP. Ce CR fera tat des rponses aux questions 1, 4, 5, 11, 12, 17, 18, 20, 21, 22 et 23. Vous tes libre d'ajouter tout lment d'information qu'il vous semblera judicieux de donner. But Lobjectif de ce TP est de faire une analyse de lempilement protocolaire en utilisant le cas dune application Web (http). Nous examinerons la structure des en-ttes des PDU (Protocol Data Unit) au niveau de la couche liaison, IP et de la couche transport TCP. Les protocoles traits

    - ladressage IP et Ethernet - Le Three-Way Handshake de TCP ainsi que la numrotation des ACK

    Procdures - Lancer Wireshark (Dmarrer -> Programmes ->Emulateurs->