[ppe projet ftp] - wordpress.com · 2015-03-06 · [ppe projet ftp] 4 2) introduction ftp file...

13
PPe jaune Domingues Almeida Nicolas Collin Leo Ferdioui Lamia Sannier Vincent [PPE PROJET FTP]

Upload: others

Post on 04-Jul-2020

7 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

PPe jaune

Domingues Almeida Nicolas Collin Leo Ferdioui Lamia Sannier Vincent

[PPE PROJET FTP]

Page 2: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

2

Sommaire 1) Architecture réseau ............................................................................... 3

2) Introduction FTP ..................................................................................... 4

3) Le rôle du protocole FTP ........................................................................ 4

4) Diagramme de gant ................................................................................ 5

5) Utilisation SCP et SFTP ........................................................................... 5

6) Installation et configuration du serveur FTP ........................................... 8

7) Sources ................................................................................................. 13

Page 3: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

3

1) Architecture réseau

Page 4: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

4

2) Introduction FTP

File Transfer Protocol. Protocole de transfert de fichier. Par extension,

nom de l'utilitaire d'Unix utilisant le protocole TCP/IP pour télécharger

des fichiers dans un sens ou dans l'autre, et d'une façon générique,

nom des programmes offrant ce service

Le FTP peut fonctionner en mode actif ou passif. Dans le premier cas,

le client contacte le serveur sur le port 21, et celui-ci rappeler sur le

port 20. Dans le monde passif, c'est le client qui initie toutes les

connexions et seul le port 21 du serveur est utilisé.

Mode actif : c'est le client FTP qui détermine sur quel port se feront les échanges de

fichiers. Cette technique est la plus ancienne et pose bien souvent des problèmes à

cause du pare-feu.

Mode passif : c'est le serveur FTP qui détermine le port d'échange des fichiers. C'est la

technique recommandée aujourd'hui.

3) Le rôle du protocole FTP

Le protocole FTP définit la façon selon laquelle des données doivent

être transférées sur un réseau TCP/IP.

Le protocole FTP a pour objectifs de :

- permettre un partage de fichiers entre machines distantes

- permettre une indépendance aux systèmes de fichiers des

machines clientes et serveur

- permettre de transférer des données de manière efficace

Page 5: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

5

4) Diagramme de gant

5) Utilisation SCP et SFTP

L'utilisation de ces commandes est relativement simple. SCP permet de faire de la copie de fichiers.

SFTP est utilisable en mode interactif ou en mode batch et ressemble plus au FTP.

Utilisation de scp

La commande

M0:$ ssh [email protected] "ls -al psionic"

-rw-r--r-- 1 root root 64562 Nov 23 23:05 hostsentry-0.02-4.noarch.rpm

-rw-r--r-- 1 root root 26955 Nov 23 23:05 logsentry-1.1.1-1.i386.rpm

-rw-r--r-- 1 root root 48804 Nov 23 23:06 portsentry-1.1-fr7.i386.rpm

-rw-r--r-- 1 root root 48804 Nov 23 23:13 portsentry-1.1-fr7.i386.rpm.1

Colonne1 Colonne2 Colonne3 Colonne4 Colonne5 Colonne6 Colonne7 Colonne8 Colonne9 Colonne10 Colonne11 Colonne12

Installation Linux

Architecture

Configuration LDAP

Configuration FTP

SFTP/SCP

Compte rendue

Page 6: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

6

La commande :

ssh [email protected] "ls -al"

donne la liste des fichiers distants qui sont dans le répertoire "psionic". Pour copier ces fichiers

localement dans un répertoire psionic on va utiliser :

cd && mkdir psionic

scp [email protected]:/home/mlx/psionic/* ~/psionic

Ou pour envoyer les fichiers du répertoire local psionic, vers le répertoire tmp qui est dans

/home/mlx de la machine M1.foo.org :

scp ~/psionic/* [email protected]:/home/mlx/tmp

Utilisation de sftp

sftp peut être utilisé pour du transfert de fichiers en mode sécurisé.

sftp [email protected]

sftp>

On obtient un prompt, ici le système ne m'a pas demandé de m'authentifier. Pour avoir une liste des

commandes, utiliser "help".

sftp> help

Available commands:

cd path Change remote directory to 'path'

Page 7: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

7

lcd path Change local directory to 'path'

chgrp grp path Change group of file 'path' to 'grp'

chmod mode path Change permissions of file 'path' to 'mode'

chown own path Change owner of file 'path' to 'own'

help Display this help text

get remote-path [local-path]Download file

lls [ls-options [path]] Display local directory listing

ln oldpath newpath Symlink remote file

lmkdir path Create local directory

lpwd Print local working directory

ls [path] Display remote directory listing

lumask umask Set local umask to 'umask'

mkdir path Create remote directory

put local-path [remote-path]Upload file

pwd Display remote working directory

exit Quit sftp

quit Quit sftp

rename oldpath newpath Rename remote file

rmdir path Remove remote directory

rm path Delete remote file

symlink oldpath newpath Symlink remote file

version Show SFTP version

!command Execute 'command' in local shell

! Escape to local shell

? Synonym for help

Page 8: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

8

6) Installation et configuration du serveur FTP

Nous nous intéressons ici à l'installation du serveur FTP. Pour commencer, connectez-vous à votre

serveur en SSH.

On se connecte en SSH :

Tout comme il existe plusieurs clients FTP, il existe plusieurs serveurs FTP :

ProFTPd

vsFTPd

PureFTPd

...

On va choisir d’utiliser ProFTPd.

On utilise apt-get pour télécharger et installer le programme ProFTPd. Lors de l'installation, on vous

posera cependant une question histoire de corser les choses :

Page 9: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

9

Il y a deux façons de lancer ProFTPd :

Depuis inetd : ProFTPd ne sera lancé que si un client se connecte à la machine par FTP. Avec

cette technique, le serveur FTP ne consomme pas de ressources sur le serveur lorsque

personne n'est connecté, mais le démarrage du serveur FTP est plus lent. On va choisir cette

option.

Indépendamment : ProFTPd est lancé dès le démarrage du serveur et tourne toujours en

toile de fond.

Globalement, la première technique est recommandée pour un serveur FTP qui a peu de connexions

par jour, et la seconde pour un serveur FTP fréquemment utilisé.

En pratique, il vaut mieux sélectionner indépendamment (qui est d'ailleurs la valeur par défaut). Le

serveur FTP n'en sera que plus réactif et les serveurs ont aujourd'hui assez de mémoire pour ne pas

être gênés par la présence d'un serveur FTP.

CONFIGURATION

Maintenant que ProFTPd est installé, allons faire un tour dans son fichier de

configuration/etc/proftpd/proftpd.conf. Pour l'ouvrir, vous pouvez utiliser l'éditeur nano (plus

simple) ou vim :

Il faut bien ouvrir le fichier en root (avec sudo) sinon vous n'aurez pas le droit de le modifier !

Le fichier ressemble à ceci :

Page 10: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

10

On retrouve une instruction par ligne. Certaines lignes sont précédées d'un dièse # : ce sont des

commentaires qui sont ignorés. Ils servent la plupart du temps à vous indiquer à quoi sert la ligne qui

suit.

Parfois, il faudra enlever le # au début d'une des lignes pour activer l'instruction qu'elle contient.

Présentation des principales directives de configuration

Voici les lignes que vous pouvez modifier (ou non) selon vos souhaits :

ServerName

Indique le nom du serveur FTP. Ce nom sera affiché lorsque des clients se connecteront au serveur.

Par défaut ici, la valeur est "Debian", vous pouvez la remplacer par ce que vous voulez ("Samba" par

exemple ).

TimeoutIdle

Le délai, en secondes, au bout duquel un client est automatiquement déconnecté s'il n'est plus actif

sur le serveur FTP.

DefaultRoot

Le répertoire auquel auront accès les personnes qui se connecteront en FTP.

Par défaut, quelqu'un qui se connecte en FTP au serveur peut accéder à tous les dossiers du serveur !

Bien qu'il ne puisse pas les modifier pour la plupart, ce n'est certainement pas quelque chose que

vous avez envie d'autoriser. Il est donc recommandé d'activer l'option DefaultRoot

Pour activer DefaultRoot, supprimez le # en début de ligne.

La valeur ~ de la commande signifie que l'utilisateur sera limité à son dossier personnel (/home/toto

par exemple). Il ne pourra pas aller "fouiller" dans d'autres dossiers.

Port

Le port de connexion au serveur FTP. La quasi-totalité du temps ce port est 21, vous ne devriez pas

avoir à le changer sauf si vous êtes bloqué par un pare-feu.

PassivePorts

Une gamme de ports autorisés pour les transferts de fichiers en mode passif.

Qu'est-ce que le mode passif ?

Pour échanger les fichiers, un serveur FTP peut utiliser l'un de ces deux modes :

L'option PassivePorts vous permet de déterminer dans quelle gamme de ports le serveur pourra

piocher pour ouvrir un canal d'échange de fichiers. La valeur par défaut est en général suffisante,

sauf si vous avez besoin de restreindre les ports à cause d'un pare-feu.

MaxInstances

Page 11: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

11

Le nombre maximum de connexions simultanées que vous voulez autoriser sur votre serveur FTP. La

valeur par défaut de 30 est généralement largement suffisante. Ne l'augmentez que si votre serveur

FTP s'apprête à être utilisé par de très nombreuses personnes.

<Anonymous ~ftp>

Vous pouvez décommenter toutes les lignes à partir de <Anonymous ~ftp> pour autoriser les

connexions anonymes à votre serveur.

Une connexion anonyme à un serveur FTP signifie que tout le monde peut s'y connecter sans

connaître de mot de passe ! Il suffit d'employer le nom d'utilisateur "anonymous".

Si vous activez les connexions anonymes sur votre serveur FTP, n'importe quel internaute pourra s'y

connecter. Il aura accès au répertoire /home/ftp en lecture seule. Il pourra lire et télécharger des

fichiers, mais pas les modifier ni ajouter de fichiers (il faudrait être fou pour autoriser tout le monde

à écrire n'importe quoi sur son serveur ! ).

Activation de la nouvelle configuration

Les modifications ne sont pas prises en compte immédiatement après que vous ayez enregistré le

fichier. Il faut demander à ProFTPd de recharger le fichier de configuration :

Si une ligne d'erreur s'affiche sous la forme unable to resolve host, cela n'est pas grave et que vous

pouvez l'ignorer.

Au besoin, sachez qu'il est possible avec des commandes similaires de :

Redémarrer le serveur FTP :sudo /etc/init.d/proftpd restart

Stopper le serveur FTP :sudo /etc/init.d/proftpd stop

Lancer le serveur FTP (s'il n'est pas déjà lancé) :sudo /etc/init.d/proftpd start

En théorie, un restart aura le même effet qu'un reload : le nouveau fichier de configuration sera pris

en compte dans les deux cas. En revanche, l'avantage de reload est que le serveur n'est pas

momentanément coupé pour prendre en compte la nouvelle configuration. Ceux qui téléchargeaient

des fichiers sur le serveur ne seront donc pas déconnectés.

SE CONNECTER A SON SERVEUR FTP

Maintenant que votre serveur FTP est installé et configuré, vous pouvais vous connectez, vous avez 2

possibilités :

Utiliser le client FTP intégré à votre navigateur web

Utiliser un client FTP dédié comme FileZilla

Page 12: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

12

Utiliser le client FTP intégré à votre navigateur web

Cette technique peut se révéler pratique si vous n'avez pas encore installé de client FTP sur votre

machine. En effet, la plupart des navigateurs web permettent aujourd'hui d'accéder à un serveur

FTP.

Il suffit de taper ftp://ip dans la barre d'adresse de votre navigateur. Remplacez "ip" par l'adresse IP

de votre serveur (que vous devez connaître !). Exemple en image :

On vous demandera ensuite votre identifiant et votre mot de passe. Utilisez ceux de votre compte

utilisateur.

Utiliser le client FTP intégré à votre navigateur web est pratique mais limité. Vous pourrez seulement

voir et télécharger des fichiers, mais ne pas en ajouter. Si vous voulez en ajouter, utilisez un vrai

client FTP comme FileZilla est nécessaire

Utiliser un client FTP dédié comme FileZilla

Une fois FileZilla installé, il suffit de remplir les champs de connexion en haut de la fenêtre :

Là encore, vous devez indiquer votre login et mot de passe. Ils correspondent aux identifiants sur la

machine que vous utilisez pour vous connecter au serveur en SSH.

Si vous ne donnez ni login ni mot de passe, FileZilla tentera de se connecter en anonyme à votre

serveur FTP. Cela ne fonctionnera que si vous avez autorisé les connexions anonymes au préalable

dans le fichier de configuration.

L'installation et la configuration d'un serveur FTP sont au final assez simple.

Notez que, pour échanger des fichiers avec un serveur, il existe d'autres techniques que le FTP :

FTPS : une version sécurisée du FTP qui crypte les échanges de fichiers, afin d'éviter qu'une

personne ne puisse les intercepter.

SFTP : une connexion qui utilise le protocole SSH et qui crypte là aussi les échanges de

fichiers. Son gros avantage est qu'il n'est pas nécessaire d'installer un serveur FTP ! Si SSH est

installé, vous devriez pouvoir vous connecter à votre serveur en SFTP. Seul défaut : il vous

faut un client qui gère ce mode de connexion. C'est le cas de FileZilla, qui vous permet de

définir dans les options de connexion le mode "SFTP". Le login et le mot de passe sont là

encore ceux de votre compte utilisateur.

Page 13: [PPE PROJET FTP] - WordPress.com · 2015-03-06 · [PPE PROJET FTP] 4 2) Introduction FTP File Transfer Protocol. Protocole de transfert de fichier. Par extension, nom de l'utilitaire

[PPE PROJET FTP]

13

Si vous en avez la possibilité, il est recommandé d'utiliser SFTP qui vous évite d'avoir à installer et

configurer un serveur FTP !

7) Sources

http://memo-linux.com/comment-installer-un-serveur-ftp-securise-sous-debian-squeeze/

http://www.crystalxp.net/forum/fr/linux/Tutoriaux-3/tutoriel-serveur-creer-sujet_31449_1.htm

http://www.pointroot.org/index.php/2011/09/03/installer-un-serveur-ftp-securise-sous-linux-

debian-proftpd/

8) Conclusion

FTP est un logiciel très utile qui peut avoir un avantage énorme pour un site Web ou à l'informatique

collaborative dans lequel les fichiers doivent être partagés entre les partenaires commerciaux.

Bien que l'insécurité, il est accessible à tous, parce que les clients FTP sont une partie de tous les

systèmes d'exploitation et navigateurs Web.

Si la sécurité du cryptage des données est d'une grande importance pour vous, alors vous devriez

probablement envisager SCP comme une alternative possible.