TP 3 Mini client/serveur ftp
|
|
- Jean-Claude Nolet
- il y a 8 ans
- Total affichages :
Transcription
1 TP 3 Mini client/serveur ftp 1 But Le but du TP est de réaliser un client et un serveur de transfert de fichiers à distance. Pour transférer un fichier (par exemple obtenir un fichier depuis une machine distante), un client établit une connexion avec le serveur situé sur cette machine, transmet sa requête, attend l'accusé de réception, puis le contenu du fichier est échangé. La connexion est fermée à la fin du transfert (il ne peut donc y avoir qu'une seule requête par connexion). 2 Un mini-client/serveur ftp Le protocole de communication à implanter est le suivant (il ne s'agit pas du vrai protocole utilisé par ftp) : Serveur lancement du serveur (ouverture du port d'écoute) attend une demande de connexion accepte une demande de connexion délègue le traitement de la requête à un fils et se remet en attente de demande de connexion le fils : lit la requête et l'identifie envoie la réponse échange les données (si nécessaire). Client demande une connexion à un serveur construit une requête envoie la requête au serveur lit la réponse du serveur vérifie la réponse échange les données (si nécessaire). 2.1 Les requêtes du client Nous spécifions seulement quelques types de requêtes (4) pour simplifier notre cahier des charges : obtention d'un fichier (REQUETE_GET), le client demande à récupérer un fichier qui est sur le serveur, envoi d'un fichier (REQUETE_PUT), le client demande à déposer un fichier sur le serveur, suppression d'un fichier sur le serveur (REQUETE_DEL), le client demande qu'un fichier du serveur soit détruit (la requête seule est envoyée, il n'y a pas de transfert de contenu), affichage du contenu d'un répertoire du serveur (REQUETE_DIR), le client demande l'exécution de «ls -la» sur un chemin du serveur 2.2 Les réponses du serveur Après avoir lu la requête, le serveur renvoie un accusé de réception au client. Cet accusé peut être : positif (ANSWER_OK), négatif (ANSWER_ERROR) ou le serveur peut ne pas avoir compris la requête (ANSWER_UNKNOWN). En outre, le client peut ne jamais récupérer d'accusé, à cause d'une coupure de la connexion. Dans le cas d'un accusé négatif, le serveur fournit aussi un code d'erreur permettant d'identifier le problème (par exemple, l'échec peut provenir d'une tentative de récupération d'un fichier inconnu sur le serveur). Pour simplifier, le serveur renvoie la valeur de la variable errno suite à l'action qui a entraîné le rejet de la requête. 2.3 La requête Lors des cas de transfert de fichier (en envoi ou en récupération), il est nécessaire de connaître la taille du fichier transféré pour savoir si, lors d'un read détectant une fin de fichier (dû à la fermeture de la connexion), tout le contenu a bien été récupéré, ou si la connexion a été rompue trop tôt. Une requête est donc de la forme : #define REQUETE_PUT 1 #define REQUETE_GET 2 #define REQUETE_DEL 3 #define REQUETE_DIR 4 G. BENAY /2008
2 struct request { int kind; char path[maxpath]; int nbbytes; /* pour PUT seulement */ ; L'entier kind doit être REQUETE_PUT, REQUETE_GET, REQUETE_DEL ou REQUETE_DIR. La chaîne path contient le nom du fichier à écrire (put), lire (get), détruire (del) ou lister (dir). L'entier nbbytes contient la taille du fichier, lors d'un PUT seulement. 2.4 La réponse Une réponse contient donc l'accusé (ack). Si la réponse est positive (ack vaut ANSWER_OK) et que la requête était un GET, nbbytes contient la taille du fichier que le serveur va envoyer. Si la réponse est négative (ANSWER_ERROR), errnum contient le code de l'erreur (valeur de la variable errno). #define ANSWER_OK 0 #define ANSWER_UNKNOWN 1 /* requete inconnue */ #define ANSWER_ERROR 2 /* erreur lors du traitement */ struct answer { int ack; int nbbytes; /* pour GET seulement */ int errnum; /* significatif ssi!= 0 et ack == ANSWER_ERROR */ ; 2.5 Ligne de commande Le serveur miniftpd est démarré sans argument. Le port est prédéfinit et imposé ; on choisira un port libre. L'exécution d'un client peut prendre l'une des formes suivantes : miniftp hostname port get distfilename localfilename miniftp hostname port put localfilename distfilename miniftp hostname port del distfilename miniftp hostname port dir distpathname 2.6 Contrôle d'accès? Un serveur ftp doit théoriquement vérifier que les fichiers sont accédés avec les droits d'accès du client, et non pas ceux du serveur (d'où une phase initiale d'authentification avec mot de passe). Dans notre cas, le serveur accède aux fichiers sous l'uid de l'utilisateur qui a lancé ce serveur. Le client peut éventuellement être d'un autre uid, mais aucun contrôle n'est effectué. 2.7 Terminaison des processus fils Pour gérer une requête, le serveur «fork» un nouveau processus. Il est intéressant de récupérer le code de retour de ce processus fils, pour pouvoir détecter, par exemple, une terminaison anormale (et cela évite en outre l'apparition de processus zombies). Il existe deux mécanismes de synchronisation avec la terminaison (qui peuvent être combinés) : l'appel système wait attend indéfiniment la terminaison d'un processus fils ; le signal SIGCHLD est envoyé au père lors de la terminaison d'un processus fils. Par défaut, ce signal est ignoré. Rappel : lorsqu'un processus est bloqué par un appel système (par exemple read ou accept) et qu'un signal lui est envoyé, l'appel système échoue et renvoie -1, avec le code d'erreur EINTR (dans la variable errno). G. BENAY /2008
3 3 Rappels sockets Un socket est un point de communication par lequel le processus peut émettre ou recevoir des informations vers ou en provenance d'un autre socket. Serveur Client cliente Le serveur crée un fils pour traiter les requêtes et lui même se remet à l'écoute socket() bind() listen() Création et attachement d'une socket d'écoute Création du service Le serveur passe en mode écoute il peut accepter des demandes de connexion socket() bind() Création de la socket Demande de connexion accept() connect() fork() read() write() recv() send() read() write() recv() send() close() close() Chaque close() ne ferme qu un seul sens de communication! 3.1 Fichiers d'en-tête #include <sys/types.h> #include <sys/param.h> #include <sys/socket.h> /* constantes, familles */ #include <netinet/in.h> /* struct sockaddr_in */ #include <arpa/inet.h> /* prototypes pour les fonctions dans inet(3n) */ #include <netdb.h> /* struct hostent */ 3.2 Le type sockaddr_in Une adresse de socket dans la famille Internet est définie par : struct sockaddr_in { short sin_family; /* la famille de protocole */ u_short sin_port; /* numero de port */ struct in_addr sin_addr; /* adresse IP de la machine */ char sin_zero[8]; /* remplissage pour faire 16 octets */ ; Rappel : L'adresse IP d'une machine (type struct in_addr) est en fait 4 octets, qu'on écrit généralement sous la forme Coté client u_long htonl (u_long hostlong); u_short htons (u_short hostshort); struct hostent *gethostbyname (char *name); G. BENAY /2008
4 int socket (int domain, int type, int protocol); int connect (int s, struct sockaddr *name, int namelen); On utilise des sockets dans la famille de protocole Internet, de type stream (fiable, fifo, bi-directionnel), créés par : socket (PF_INET, SOCK_STREAM, 0). Pour la connexion (serverhost est le nom de la machine que l'on veut contacter, port est le numéro du port sur cette machine) : { int sc; struct hostent *sp; struct sockaddr_in sins; /* Obtention d'information au sujet de la machine `serverhost' */ sp = gethostbyname (serverhost); if (sp == NULL) { fprintf (stderr, "gethostbyname: %s not found\n", serverhost); exit (1); /* Creation d'un socket Internet de type stream (fiable, bi-directionnel) */ sc = socket (PF_INET, SOCK_STREAM, 0); if (sc == -1) { perror ("socket failed"); exit (1); /* Remplissage de la structure `sins' avec la famille de protocoles Internet, * le numero IP de la machine a contacter et le numero de port. */ sins.sin_family = AF_INET; memcpy (&sins.sin_addr, sp->h_addr_list[0], sp->h_length); sins.sin_port = htons (port); /* Tentative d'etablissement de la connexion. */ if (connect (sc, (struct sockaddr *)&sins, sizeof(sins)) == -1) { perror ("connect failed"); exit (1); 3.4 Coté serveur int socket (int domain, int type, int protocol); int setsockopt (int s, int level, int optname, char *optval, int optlen); int bind (int s, struct sockaddr *name, int namelen); int listen (int s, int backlog); int accept (int s, struct sockaddr *addr, int *addrlen); Ce qui s'utilise (port est le numéro du port sur lequel écoute le serveur) : { struct sockaddr_in soc_in; int val; int ss; /* socket Internet, de type stream (fiable, bi-directionnel) */ ss = socket (PF_INET, SOCK_STREAM, 0); /* Force la reutilisation de l'adresse si non allouee */ val = 1; setsockopt (ss, SOL_SOCKET, SO_REUSEADDR, &val, sizeof(val)); /* Nomme le socket: socket inet, port PORT, adresse IP quelconque */ soc_in.sin_family = AF_INET; soc_in.sin_addr.s_addr = htonl (INADDR_ANY); soc_in.sin_port = htons (port); G. BENAY /2008
5 bind (ss, &soc_in, sizeof(soc_in)); /* Prepare le socket a la reception de connexions */ listen (ss, 5); while (1) { struct sockaddr_in from; int len; int f; /* Accepte une connexion. * Les parametres `from' et `len' peuvent etre NULL. */ len = sizeof (from); f = accept (ss, (struct sockaddr *)&from, &len); /* */ Attention : il manque le traitement d'erreur, qui est indispensable avec les sockets, du fait de la forte probabilité de défaillance. 4 Rappels Unix Tous les appels systèmes renvoient -1 en cas d'erreur. Dans ce cas, la variable errno contient le code de l'erreur. 4.1 Obtenir des informations sur un fichier : stat Pour obtenir des information sur un fichier, utiliser : int stat (char *pathname, struct stat *buf); int fstat (int fd, struct stat *buf); La structure struct stat contient de nombreux champs (voir man stat pour plus de détails), dont st_uid (propriétaire du fichier), st_size (taille du fichier), st_mode (droit d'accès), st_mtime (date de dernière modification) #include <sys/types.h> #include <sys/stat.h> main (int argc, char **argv) { struct stat buf; if (stat (argv[1], &buf) == -1) perror (argv[1]); else printf ("%s: proprietaire %d, taille %d\n", argv[1], buf.st_uid, buf.st_size); 4.2 Ouverture d'un fichier open Pour obtenir un descripteur de fichier permettant d'accèder (lecteur ou écriture) à un fichier, on utilise l'appel système open. Les trois formes d'utilisation habituelles sont : int fd = open ("toto", O_RDONLY); int fd = open ("toto", O_WRONLY O_CREAT O_TRUNC, 0644); int fd = open ("toto", O_WRONLY O_CREAT O_EXCL, 0644); if (fd == -1) { erreur La première ligne ouvre le fichier en lecture ; la deuxième ouvre le fichier pour écriture, avec création s'il n'existe pas et troncature s'il existe déjà ; la troisième ligne ouvre le fichier pour écriture, avec création s'il n'existe pas et erreur s'il existe déjà. Le troisième argument est utilisé pour définir les droits d'accès (ici rw-r--r--) s'il y a création du G. BENAY /2008
6 fichier. 4.3 Destruction d'un fichier unlink L'appel système : int unlink (char *pathname); détruit le lien spécifié par pathname. Si ce lien était le dernier lien vers le fichier, le fichier est effacé. 4.4 Lecture/écriture read/write int read (int fd, void *buf, int nbyte); int write (int fd, const void *buf, int nbyte); L'appel système read lit sur le descripteur au plus nbyte octets et les range à l'adresse buf. Il renvoie le nombre d'octets effectivement lus, ou 0 si la «fin de fichier» a été atteinte (il n'y a et il n'y aura plus rien à lire : socket fermé ou fichier complètement lu), ou -1 en cas d'erreur. L'appel système write écrit sur le descripteur au plus nbyte octets rangés à l'adresse buf. Il renvoie le nombre d'octets effectivement écrits, ou -1 en cas d'erreur. Quand read ou write sont appliqués à un fichier, le nombre d'octets lus ou écrits est toujours le nombre demandé (sauf lorsque la fin du fichier est atteinte) ; quand ils sont appliqués à un descripteur associé à un socket, le nombre d'octets lus ou écrits peut être inférieur au nombre demandé. 4.5 Les signaux Un signal est un événement asynchrone auquel il est possible d'associer un traitement spécifique (une procédure qui sera invoquée par le système à la délivrance du signal). En absence de traitement, un signal entraîne en général la mort du processus destinataire. L'association d'un traitement se fait au moyen de la primitive signal : void traitement_sig (int sig) { signal (SIGCHLD, traitement_sig); /* remise en place du traitement */ main() { signal (SIGCHLD, traitement_sig); 5 Déroulement des tps Fournis dans un paquet zip (miniftp.zip) ou tar (miniftp.tgz): requetes.h : les types et macro-définitions utiles ; common.h, common.c : deux petites procédures bien utiles, notamment copy_n_bytes ; miniftp.c : l'architecture du client ; miniftpd.c : l'architecture du serveur ; Makefile : pour compiler. 5.1 Le Client écriture du client miniftp. Le code get est déjà fourni, compiler et exécuter en utilisant le serveur sur kirov ou karkov (port 38590) ; écrire les autres requêtes ; écrire le code des autres requêtes (put, dir, del) ; valider l'ensemble. 5.2 Le Serveur écriture du serveur miniftpd. La réponse à la requête get est fournie. écrire les autres réponses aux requêtes (put, dir, del) ; valider soigneusement. 5.3 Rapport Rappel vous devez fournir un rapport avec l'ensemble des programmes : Le serveur, Le client, Une présentation des fonctions réalisées. G. BENAY /2008
7 1. Personne seule TP3 Reseau NomGrooupeEI2 Nom.zip NomGrooupeEI2 : le nom du groupe EI2 (EI2AD, EI2AG, ou EI-I2B) Nom1 votre nom si seul, 2. Binôme TP3 Reseau NomGrooupeEI2 Nom1 Nom2.zip NomGrooupeEI2 : le nom du groupe EI2 (EI2AD, EI2AG, ou EI-I2B) Nom1 le nom d'un des membres du binôme Nom2 le nom de l'autre membre du binôme Vous envoyez votre rapport par courrier électronique à l'adresse : gerard.benay@cnam.fr au plus tard le : EI I2AG : Vendredi 6 juin 2008 EI I2AD : Vendredi 30 mai 2008 EI I2B : Vendredi 30 mai 2008 G. BENAY /2008
Programmation système de commandes en C
Programmation système de commandes en C Cours de Programmation système Tuyêt Trâm DANG NGOC Université de Cergy-Pontoise 2012 2013 Tuyêt Trâm DANG NGOC Programmation système de commandes
Plus en détailCommunication par sockets
Rappel : le réseau vu de l!utilisateur (1) Communication par sockets Sacha Krakowiak Université Joseph Fourier Projet Sardes (INRIA et IMAG-LSR) http://sardes.inrialpes.fr/~krakowia (demande un service)
Plus en détailCours 6 : Tubes anonymes et nommés
Cours 6 : Tubes anonymes et nommés Mécanisme de communications du système de fichiers I-node associé. Type de fichier: S_IFIFO. Accès au travers des primitives read et write. Les tubes sont unidirectionnels
Plus en détailApplications client/serveur TCP/IP - Sockets Rappels. C.Crochepeyre Applications CS 1
Applications client/serveur TCP/IP - Sockets Rappels C.Crochepeyre Applications CS 1 PLAN Modèle client/serveur Modèle ISO et protocole TCP/IP Comment ça marche? La programmation: les sockets Exemples
Plus en détail1. Fonctionnement de l Internet 2. Protocoles applicatifs 3. Programmation réseau
1. Fonctionnement de l Internet 2. Protocoles applicatifs 3. Programmation réseau Fonctionnement de l Internet Fonctionnement de l Internet Basé sur une architecture TCP/IP du nom des deux principaux protocoles
Plus en détailTravaux Pratiques Introduction aux réseaux IP
Université de Savoie Initiation aux réseaux IP Travaux Pratiques Introduction aux réseaux IP Sylvain MONTAGNY sylvain.montagny@univ-savoie.fr Bâtiment chablais, bureau 13 04 79 75 86 86 TP1 : Analyse la
Plus en détailCours Programmation Système
Cours Programmation Système Filière SMI Semestre S6 El Mostafa DAOUDI Département de Mathématiques et d Informatique, Faculté des Sciences Université Mohammed Premier Oujda m.daoudi@fso.ump.ma Février
Plus en détailCommunication sous UNIX les sockets
Communication sous UNIX les sockets Chaput Emmanuel Version 1.04 Résumé Ce but de ce petit document est de décrire la programmation des sockets sous Unix afin d aider le programmeur à développer des applications
Plus en détailProgrammation système en C/C++
Programmation système en C/C++ Jean-Baptiste Vioix (jb.vioix@free.fr) LE2I - ENESAD http://jb.vioix.free.fr 1-41 Programmation en C/C++ sous Unix Il existe des très nombreux outils de développement sous
Plus en détailLA COUCHE TRANSPORT CONTRÔLE LE FLOT DE DONNEES TRANSMISES par la couche Réseau
M1 Informatique Réseaux Cours 6 Couche Transport : TCP et UDP Notes de Cours LA COUCHE TRANSPORT CONTRÔLE LE FLOT DE DONNEES TRANSMISES par la couche Réseau dans le but d offrir des garanties de service
Plus en détail3IS - Système d'exploitation linux - Programmation système
3IS - Système d'exploitation linux - Programmation système 2010 David Picard Contributions de : Arnaud Revel, Mickaël Maillard picard@ensea.fr Environnement Les programmes peuvent être exécutés dans des
Plus en détailProgrammation système I Les entrées/sorties
Programmation système I Les entrées/sorties DUT 1 re année Université de Marne La vallée Les entrées-sorties : E/O Entrées/Sorties : Opérations d échanges d informations dans un système informatique. Les
Plus en détailDUT Informatique Module Système S4 C Département Informatique 2009 / 2010. Travaux Pratiques n o 5 : Sockets Stream
iut ORSAY DUT Informatique Département Informatique 2009 / 2010 Travaux Pratiques n o 5 : Sockets Stream Nom(s) : Groupe : Date : Objectifs : manipuler les primitives relatives à la communication par sockets
Plus en détailPlaying with ptrace() for fun and profit
sous GNU/Linux nicolas.bareil@eads.net EADS Corporate Research Center - DCR/STI/C SSI Lab SSTIC 2006 Il était une fois... Sous UNIX, ptrace() est le seul moyen de debuggage. User-space, Interface rigide
Plus en détailProgrammation Réseau. Anthony Busson IUT Info Lyon 1
Programmation Réseau Anthony Busson IUT Info Lyon 1 Plan du cours Introduction Rôles du système et des applications Rappel TCP-IP Panorama des langages Couche socket : introduction Panorama de la couche
Plus en détailLe service FTP. M.BOUABID, 04-2015 Page 1 sur 5
Le service FTP 1) Présentation du protocole FTP Le File Transfer Protocol (protocole de transfert de fichiers), ou FTP, est un protocole de communication destiné à l échange informatique de fichiers sur
Plus en détailProgrammation Réseau en C sous Unix
Chapitre 1 : Notions de base I. Structure d adresse : En programmation réseau, nous allons utiliser les sockets. C est un moyen de communication qui se définit par un port et une adresse. Elle est représentée
Plus en détailExercice sur les Dockers
Exercice sur les Dockers Les parties composant les Dockers: 1 docker daemon: est un démon qui gère les dockers (les conteneurs LXC) qui tournent sur la machine hôte 2 docker CLI: une série de commandes
Plus en détailLe système de gestion des fichiers, les entrées/sorties.
Le système de gestion des fichiers, les entrées/sorties. Luigi Santocanale Laboratoire d Informatique Fondamentale, Centre de Mathématiques et Informatique, 39, rue Joliot-Curie - F-13453 Marseille 19
Plus en détailLe prototype de la fonction main()
Le prototype de la fonction main() 1. Introduction...1 2. Paramètres et type de retour de la fonction main()...1 3. Exemple 1...2 4. La fonction exit() du C...2 5. Détecter le code de retour d un programme
Plus en détailTRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique
Communications entre Processus Communication par tubes. TRAVAUX PRATIQUES Programmation Système Langage C / Système UNIX. 2 e année Génie Informatique Exemple 1: On a deux processus Père/Fils. Le père
Plus en détailGESTION DES FICHIERS C/UNIX
Licence IG Page 1 sur 6 GESTION DES FICHIERS C/UNIX Introduction Deux modes d appel - Par la bibliothèque standard C (appel de haut niveau) - Par appels système (bas niveau) Nécessite les includes suivant
Plus en détailSimulation d un système de paiement par carte bancaire
Simulation d un système de paiement par carte bancaire Mini projet IN301/IN3ST01-2009-2010 Sujet rédigé par Jean Cousty et Laurent Najman, très librement inspiré d un projet de Jérome Gueydan pour l ENSTA
Plus en détailLes messages d erreur d'applidis Client
Fiche technique AppliDis Les messages d erreur d'applidis Client Fiche IS00313 Version document : 1.00 Diffusion limitée : Systancia, membres du programme Partenaires AppliDis et clients ou prospects de
Plus en détailDans le chapitre 1, nous associions aux fichiers ouverts des descripteurs de fichiers par lesquels nous accédions aux fichiers.
I Présentation : Dans le chapitre 1, nous avons vu comment utiliser les appels-systèmes de bas niveau pour créer et accéder à des fichiers sur le disque. Nous avons notamment mis en évidence leur dépouillement
Plus en détailDNS Server RPC Interface buffer overflow. Céline COLLUMEAU Nicolas BODIN
Mémoire DNS Server RPC Interface buffer overflow Céline COLLUMEAU Nicolas BODIN 3 janvier 2009 Table des matières 1 Introduction 2 2 Présentation de la faille 3 3 Exemple d exploitation 5 4 Solutions 10
Plus en détailStockage du fichier dans une table mysql:
Stockage de fichiers dans des tables MYSQL avec PHP Rédacteur: Alain Messin CNRS UMS 2202 Admin06 30/06/2006 Le but de ce document est de donner les principes de manipulation de fichiers dans une table
Plus en détailProgrammation Internet en Java
Chapitre 8 Programmation Internet en Java Vous avez déjà utilisé Internet, le plus connu des inter-réseaux mondiaux d ordinateurs et quelques-uns de ses services, en particulier le web et le courrier électronique.
Plus en détailIntroduction à la Programmation Parallèle: MPI
Introduction à la Programmation Parallèle: MPI Frédéric Gava et Gaétan Hains L.A.C.L Laboratoire d Algorithmique, Complexité et Logique Cours du M2 SSI option PSSR Plan 1 Modèle de programmation 2 3 4
Plus en détailLes commandes relatives aux réseaux
SHELL Les commandes relatives aux réseaux L'accès aux ou via les réseaux est devenu vital, aussi, les commandes traditionnelles de connexion et de transfert de fichiers ont été remplacées par des commandes
Plus en détailArguments d un programme
Arguments d un programme L2 SPI, Bruno Jacob 1 Arguments Quand on appelle un programme dans un environnement UNIX ou MS- DOS, on compose une ligne de commandes de la forme : nom-du-programme argument1
Plus en détailPlan global. Programmation système II. Socket du domaine UNIX. Plan. Socket UNIX, Terminaux, Async IO, Mémoire, ELF.
Programmation système II Socket UNIX, Terminaux, Async IO, Mémoire, ELF Timothée Ravier LIFO, INSA-CVL, LIPN 1 re année cycle ingénieur STI 2013 2014 Plan global 1 Socket UNIX 2 Terminaux 3 Autres modèles
Plus en détailSeance 2: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu.
Seance 2: Complétion du code de jeu. (durée max: 2h) Mot clé const et pointeurs: En respectant la méthode de programmation par contrat, implémentez les autres fonctions de jeu. Implémentez jeu_recupere_piece
Plus en détailOS Réseaux et Programmation Système - C5
OS Réseaux et Programmation Système - C5 Rabie Ben Atitallah rabie.benatitallah@univ-valenciennes.fr RPC - XDR Rappel RPC: Remote Procedure Call Besoin d un environnement de haut niveau pour le développement
Plus en détailPlan. Le système de transfert de fichiers d'internet. Introduction aux systèmes de transfert de fichiers Le protocole FTP.
Le système de transfert de fichiers d'internet Bernard Cousin Université de Rennes I laboratoire IRISA http://www.univ-rennes1.fr/ Plan Introduction aux systèmes de transfert de fichiers Le protocole FTP
Plus en détailGestion des fichiers. Telecom-ParisTech BCI Informatique
319 Gestion des fichiers 1 Généralités Définitions Organisation logique, organisation physique 2 Organisation physique UNIX : i-list et i-node rappels sur le fonctionnement d'un disque 3 Organisation logique
Plus en détailCommunication inter-processus (IPC) : tubes & sockets. exemples en C et en Java. F. Butelle
F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Communication inter-processus (IPC) : tubes & sockets exemples en C et en Java F. Butelle F. Butelle, E. Viennet, Système GTR2 IUT Paris 3 Java : implémentation
Plus en détailTP Sur SSH. I. Introduction à SSH. I.1. Putty
I. Introduction à SSH TP Sur SSH Le protocole SSH (pour Secure Shell) est le remplaçant de rsh (remote shell) qui correspond grosso-modo à telnet. Comme nous le verrons, SSH permet bien plus de choses
Plus en détailProgrammation client-serveur sockets - RPC
Master Informatique M Plan de la suite Programmation client-serveur sockets - RPC Sacha Krakowiak Université Joseph Fourier Projet Sardes (INRIA et IMAG-LSR) http://sardes.inrialpes.fr/people/krakowia
Plus en détailCours de Système : Gestion de Fichiers
Cours de Système : Gestion de Fichiers Bertrand Le cun et Emmanuel Hyon bertrand.le cun{at}u-paris10.fr et Emmanuel.Hyon{at}u-paris10.fr Université Paris Ouest Nanterre 25 octobre 2011 B.L.C. & E.H. (UPO)
Plus en détailLEs processus coopèrent souvent pour traiter un même problème. Ces
Chapitre 5 Communication interprocessus LEs processus coopèrent souvent pour traiter un même problème. Ces processus s exécutent en parallèle sur un même ordinateur (monoprocesseur ou multiprocesseurs)
Plus en détailProcessus! programme. DIMA, Systèmes Centralisés (Ph. Mauran) " Processus = suite d'actions = suite d'états obtenus = trace
Processus 1) Contexte 2) Modèles de Notion de Points de vue Modèle fourni par le SX Opérations sur les 3) Gestion des Représentation des Opérations 4) Ordonnancement des Niveaux d ordonnancement Ordonnancement
Plus en détailftp & sftp : transférer des fichiers
ftp & sftp : transférer des fichiers Le FTP (File Transfer Protocol) est un protocole permettant d'échanger des fichiers sur le réseau. Il est assez ancien (1985) et toujours utilisé à l'heure actuelle
Plus en détailIntroduction au langage C
Introduction au langage C Cours 1: Opérations de base et premier programme Alexis Lechervy Alexis Lechervy (UNICAEN) Introduction au langage C 1 / 23 Les premiers pas Sommaire 1 Les premiers pas 2 Les
Plus en détailLes processus. Système L3, 2014-2015 1/39
Les processus Système L3, 2014-2015 1/39 Les processus Processus = Instance d un programme en cours d exécution plusieurs exécutions de programmes plusieurs exécutions d un même programme plusieurs exécutions
Plus en détailCahier des charges. driver WIFI pour chipset Ralink RT2571W. sur hardware ARM7
Cahier des charges driver WIFI pour chipset Ralink RT2571W sur hardware ARM7 RevA 13/03/2006 Création du document Sylvain Huet RevB 16/03/2006 Fusion des fonctions ARP et IP. SH Modification des milestones
Plus en détaille minimum pour communiquer par réseau (sans toutefois y comprendre grand chose)
L API socket en résumé le minimum pour communiquer par réseau (sans toutefois y comprendre grand chose) Fabrice HARROUET École Nationale d Ingénieurs de Brest http://www.enib.fr/~harrouet/ enib 1/58 Propos
Plus en détailInstallation d'un serveur DHCP sous Windows 2000 Serveur
Installation d'un serveur DHCP sous Windows 2000 Serveur Un serveur DHCP permet d'assigner des adresses IP à des ordinateurs clients du réseau. Grâce à un protocole DHCP (Dynamic Host Configuration Protocol),
Plus en détailPrésentation du modèle OSI(Open Systems Interconnection)
Présentation du modèle OSI(Open Systems Interconnection) Les couches hautes: Responsables du traitement de l'information relative à la gestion des échanges entre systèmes informatiques. Couches basses:
Plus en détailIntroduction aux Systèmes et aux Réseaux
Introduction aux Systèmes et aux Réseaux Cours 5 Processus D après un cours de Julien Forget (univ Lille1) Laure Gonnord http://laure.gonnord.org/pro/teaching/ Laure.Gonnord@univ-lyon1.fr Master CCI -
Plus en détailLes chaînes de caractères
Les chaînes de caractères Dans un programme informatique, les chaînes de caractères servent à stocker les informations non numériques comme par exemple une liste de nom de personne ou des adresses. Il
Plus en détailSTS SE. FreeRTOS. Programmation réseau WIFI. Programmation réseau. Socket Tcp. FlyPort smart Wi-Fi 802.11 module
François SCHNEIDER Lycée Victor-Hugo BESANÇON. STS SE FreeRTOS Programmation réseau WIFI Programmation réseau Socket Tcp FlyPort smart Wi-Fi 802.11 module Prérequis : langage C, connaissance réseau : Ip,
Plus en détailProgrammation impérative
Programmation impérative Cours 4 : Manipulation des fichiers en C Catalin Dima Organisation des fichiers Qqs caractéristiques des fichiers : Nom (+ extension). Chemin d accès absolu = suite des noms des
Plus en détailEPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE
EPREUVE OPTIONNELLE d INFORMATIQUE CORRIGE QCM Remarque : - A une question correspond au moins 1 réponse juste - Cocher la ou les bonnes réponses Barème : - Une bonne réponse = +1 - Pas de réponse = 0
Plus en détailNmap (Network Mapper) Outil d exploration réseau et scanneur de ports/sécurité
Nmap (Network Mapper) Outil d exploration réseau et scanneur de ports/sécurité 1. Présentation Nmap est un outil open source d'exploration réseau et d'audit de sécurité, utilisé pour scanner de grands
Plus en détailGuide de configuration de la Voix sur IP
Le serveur Icewarp Guide de configuration de la Voix sur IP Version 11 Mai 2014 i Sommaire Guide de configuration VoIP 1 Présentation... 1 Configuration... 1 Configuration réseau... 1 Configuration du
Plus en détailCompression de Données - Algorithme de Huffman Document de Conception
ROLLET Samuel SALLE Jennifer Compression de Données - Algorithme de Huffman Document de Conception Projet d'algorithmique et Structure des Données 1 SOMMAIRE 1. Domaine d application....4 1.1 Objectifs
Plus en détailÉcole Polytechnique de Montréal. Département de Génie Informatique et Génie Logiciel. Cours INF2610. Contrôle périodique.
École Polytechnique de Montréal Département de Génie Informatique et Génie Logiciel Cours INF2610 Contrôle périodique Automne 2013 Date : 11 octobre 2013 de 18h à 20h Professeur : Boucheneb Hanifa Documentation
Plus en détailRéseaux IUP2 / 2005 DNS Système de Noms de Domaine
Réseaux IUP2 / 2005 DNS Système de Noms de Domaine 1 Noms symboliques Nommer les machines par un nom plutôt que par son adresse IP Chaîne de caractères Plus "naturel" Espace de noms hiérarchique plutôt
Plus en détailI. Introduction aux fonctions : les fonctions standards
Chapitre 3 : Les fonctions en C++ I. Introduction aux fonctions : les fonctions standards A. Notion de Fonction Imaginons que dans un programme, vous ayez besoin de calculer une racine carrée. Rappelons
Plus en détailIntroduction à JDBC. Accès aux bases de données en Java
Introduction à JDBC Accès aux bases de données en Java Eric Cariou Université de Pau et des Pays de l'adour Département Informatique Eric.Cariou@univ-pau.fr 1 Introduction JDBC : Java Data Base Connectivity
Plus en détailCentre CPGE TSI - Safi 2010/2011. Algorithmique et programmation :
Algorithmique et programmation : STRUCTURES DE DONNÉES A. Structure et enregistrement 1) Définition et rôle des structures de données en programmation 1.1) Définition : En informatique, une structure de
Plus en détailWEBMESTRE : CONCEPTION DE SITES ET ADMINISTRATION DE SERVEURS WEB
WEBMESTRE : CONCEPTION DE SITES ET ADMINISTRATION DE SERVEURS WEB Installation et administration d un serveur web Module 25793 TP A5 (1/2 valeur) Chapitre 14 Mise en place d un serveur ftp Le plus grand
Plus en détail03/04/2007. Tâche 1 Tâche 2 Tâche 3. Système Unix. Time sharing
3/4/27 Programmation Avancée Multimédia Multithreading Benoît Piranda Équipe SISAR Université de Marne La Vallée Besoin Programmes à traitements simultanés Réseau Réseau Afficher une animation en temps
Plus en détailQu'est-ce qu'un processus: Définitions
Version septembre 2013 N 187 Qu'est-ce qu'un processus: Définitions Instruction = indécomposable et indivisible Processeur =... Processus = suite temporelle d'exécutions d'instructions Processus = exécution
Plus en détailEPREUVE PRATIQUE DES TECHNIQUES INFORMATIQUES ACTIVITE N 1. Thème de l activité : Configuration d un firewall
B.T.S Informatique de Gestion Option Administrateur de Réseaux Locaux d Entreprise Session 2004/2005 EPREUVE PRATIQUE DES TECHNIQUES INFORMATIQUES Nom et prénom du candidat : TAGLIAFERRI Eric ACTIVITE
Plus en détailDéveloppement d un logiciel de messagerie instantanée avec Dotnet (version simplifiée)
Développement d un logiciel de messagerie instantanée avec Dotnet (version simplifiée) Propriétés Description Intitulé long Formation concernée Matière Présentation Développement d un logiciel de messagerie
Plus en détail1/24. I passer d un problème exprimé en français à la réalisation d un. I expressions arithmétiques. I structures de contrôle (tests, boucles)
1/4 Objectif de ce cours /4 Objectifs de ce cours Introduction au langage C - Cours Girardot/Roelens Septembre 013 Du problème au programme I passer d un problème exprimé en français à la réalisation d
Plus en détailTravaux pratiques. Compression en codage de Huffman. 1.3. Organisation d un projet de programmation
Université de Savoie Module ETRS711 Travaux pratiques Compression en codage de Huffman 1. Organisation du projet 1.1. Objectifs Le but de ce projet est d'écrire un programme permettant de compresser des
Plus en détailApplication de lecture de carte SESAM-Vitale Jeebop
Application de lecture de carte SESAM-Vitale Jeebop Présentation Le module de lecture de carte SESAM-Vitale Jeebop est une application Java Web Start, c'est à dire une application Java qui se télécharge
Plus en détailClasse ClInfoCGI. Fonctions membres principales. Gestion des erreurs
Utilisation des classes de PourCGI par Michel Michaud, version 2002-11-23 Les fichiers PourCGI.h et PourCGI.cpp rendent disponibles deux classes et une fonction libre qui permettent de faire facilement
Plus en détail1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.
1. Structure d un programme C Un programme est un ensemble de fonctions. La fonction "main" constitue le point d entrée pour l exécution. Un exemple simple : #include int main() { printf ( this
Plus en détailTP n 2 : Installation et administration du serveur ProFTP. Partie 1 : Fonctionnement du protocole FTP (pas plus de 15min)
TP n 2 : Installation et administration du serveur ProFTP Objectifs du TP Comprendre le fonctionnement du protocole FTP Installation et compilation d un paquet source Configuration, lancement et administration
Plus en détailMISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES. Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année
2003-2004 Université Paris Dauphine IUP Génie Mathématique et Informatique 2 ème année MISE A NIVEAU INFORMATIQUE LANGAGE C - EXEMPLES DE PROGRAMMES Maude Manouvrier La reproduction de ce document par
Plus en détailCours 14 Les fichiers
Cours 14 Les fichiers F. Gayral 1 Fichier : définition /media/travaux/documents/fgenseignement/java1/courstpsfgfc/14-fichiers/voirtypefichiers Fichier = ensemble d informations codées et stockées sur une
Plus en détailLe protocole TCP. Services de TCP
Le protocole TCP TCP (Transmission Control Procedure) est un protocole de transport bout-en-bout (Host-To- Host) Ajoute les fonctions que le réseau ne peut offrir et qui sont demandées par les applications
Plus en détailMicrosoft Windows NT Server
Microsoft Windows NT Server Sommaire : INSTALLATION DE WINDOWS NT SERVER... 2 WINNT.EXE OU WINNT32.EXE... 2 PARTITION... 2 FAT OU NTFS... 2 TYPE DE SERVEUR... 2 Contrôleur principal de Domaine (CPD)....
Plus en détailFoucart Digeon SISR1-CH7 Mise en place d'un serveur FTP BTS SIO 08/04/2013. SISR1 CH7 Mise en place d'un serveur FTP. - Page 1 -
SISR1 CH7 Mise en place d'un serveur FTP - Page 1 - Sommaire Application 1 : Serveur FTP sous Windows 2003...3 Préambules...3 Manipulation sur le Serveur FTP...4 Manipulation sur le client FTP...11 Application
Plus en détailPrincipes de DHCP. Le mécanisme de délivrance d'une adresse IP à un client DHCP s'effectue en 4 étapes : COMMUTATEUR 1. DHCP DISCOVER 2.
DHCP ET TOPOLOGIES Principes de DHCP Présentation du protocole Sur un réseau TCP/IP, DHCP (Dynamic Host Configuration Protocol) permet d'attribuer automatiquement une adresse IP aux éléments qui en font
Plus en détailGestion distribuée (par sockets) de banque en Java
Gestion distribuée (par sockets) de banque en Java Université Paris Sud Rappel sur la solution locale de gestion simple de banque L objet de cet exercice était de créer une application java qui implante
Plus en détailProgrammation Réseau. ! UFR Informatique ! 2013-2014. Jean-Baptiste.Yunes@univ-paris-diderot.fr
Programmation Réseau Jean-Baptiste.Yunes@univ-paris-diderot.fr! UFR Informatique! 2013-2014 1 Programmation Réseau Introduction Ce cours n est pas un cours de réseau on y détaillera pas de protocoles de
Plus en détailProtocoles réseaux. Abréviation de Binary Digit. C'est la plus petite unité d'information (0, 1).
Chapitre 5 Protocoles réseaux Durée : 4 Heures Type : Théorique I. Rappel 1. Le bit Abréviation de Binary Digit. C'est la plus petite unité d'information (0, 1). 2. L'octet C'est un ensemble de 8 bits.
Plus en détailLe Network File System de Sun (NFS)
1 sur 5 Le Network File System de Sun (NFS) Le Network File System de Sun (NFS) Architecture Protocoles Mounting Automounting vs Static mounting Directory et accès aux fichiers Problèmes Implémentation
Plus en détailGENERALITES. COURS TCP/IP Niveau 1
GENERALITES TCP/IP est un protocole inventé par les créateurs d Unix. (Transfer Control Protocol / Internet Protocole). TCP/IP est basé sur le repérage de chaque ordinateur par une adresse appelée adresse
Plus en détailGuide de référence rapide sur la messagerie vocale d'avaya Distributed Office
Téléphonie Centres d'appels Mobilité Services Guide de référence rapide sur la messagerie vocale d'avaya Distributed Office 03-602108-FR Édition 1 Mai 2007 Ce guide explique comment utiliser la messagerie
Plus en détailJava Licence Professionnelle CISII, 2009-10
Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation
Plus en détailPour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère
L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la
Plus en détailL3 informatique TP n o 2 : Les applications réseau
L3 informatique TP n o 2 : Les applications réseau Sovanna Tan Septembre 2009 1/20 Sovanna Tan L3 informatique TP n o 2 : Les applications réseau Plan 1 Transfert de fichiers 2 Le Courrier électronique
Plus en détailCouche application. La couche application est la plus élevée du modèle de référence.
Couche application La couche application est la plus élevée du modèle de référence. Elle est la source et la destination finale de toutes les données à transporter. Couche application La couche application
Plus en détailLinux LTE 2 - ISSBA. Année universitaire 2007-2008. Linux Réseau et Archivage. Jean-Michel RICHER Faculté des Sciences, H206 1
Linux LTE 2 - ISSBA Année universitaire 2007-2008 Linux Réseau et Archivage Jean-Michel RICHER Faculté des Sciences, H206 1 Plan L identification Réseau Qu est ce qu un adresse IP Classes de réseau Les
Plus en détailGuide d'utilisation du portail d'authentification Cerbère à usage des professionnels et des particuliers
RAPPORTS Secrétariat Général Service des Politiques Supports et des Systèmes d'information Centre de prestations et d'ingénierie Informatiques Département Opérationnel Sud-Ouest PNE Sécurité 10/11/2011
Plus en détailSupervision des applications et services réseaux
Chapitre 3 Supervision des applications et services réseaux 1. Qu'est-ce que la supervision des applications et services réseaux? La supervision des services réseaux et des applications permet de contrôler
Plus en détailGestion de la mémoire
433 43 3 Gestion de la mémoire + 1. Qu'est-ce que la mémoire? - Définitions, exemples 2. Allocation contiguë en mémoire - Partitions de taille fixe, de taille variable 3. Pagination et mémoire virtuelle
Plus en détailLes structures de données. Rajae El Ouazzani
Les structures de données Rajae El Ouazzani Les arbres 2 1- Définition de l arborescence Une arborescence est une collection de nœuds reliés entre eux par des arcs. La collection peut être vide, cad l
Plus en détailLe Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr
Le Langage C Version 1.2 c 2002 Florence HENRY Observatoire de Paris Université de Versailles florence.henry@obspm.fr Table des matières 1 Les bases 3 2 Variables et constantes 5 3 Quelques fonctions indispensables
Plus en détailGRETA SISR1 TP Installation et mise en place d un serveur FTP sous Windows Server 2013
Sommaire Application 1 : Serveur FTP sous Windows 2003... Préambule... Mise en place dus erveur FTP... Mise en place du client FTP... Application 2 : Serveur FTP sous XP avec Typsoft FTP Préambule Je vérifie
Plus en détailNOTE D'APPLICATION CONCERNANT LA MISE EN SERVICE DE MATERIELS SUR RESEAU IP
NOTE D'APPLICATION CONCERNANT LA MISE EN SERVICE DE MATERIELS SUR RESEAU IP Version 01 08/2004 1/5 C:\TECHNIQU\NOTICES\REVENTE\NOTE_APPLICATION\NOTE_MATERIELS_SUR_IP.sxw Sur les matériels raccordables
Plus en détailTP réseaux 4 : Installation et configuration d'un serveur Web Apache
TP réseaux 4 : Installation et configuration d'un serveur Web Apache Objectifs Installer, configurer, lancer et administrer le serveur Web Apache sous Linux Données de base machine fonctionnant sous Linux
Plus en détailLier Erlang avec d autres langages de programmation
16 Lier Erlang avec d autres langages de programmation Les logiciels actuels, quelle que soit leur taille, sont souvent écrits dans plusieurs langages de programmation. Généralement, les pilotes de périphériques
Plus en détail