Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori (a.a. 2010/11)

Documenti analoghi
Protocolli applicativi: FTP ed SMTP

Protocolli applicativi: FTP, SMTP, POP/IMAP

Programmazione in Rete

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori (a.a. 2011/12)

Reti di Calcolatori:

. SMTP, POP, IMAP. mail server. smtp [RFC 821] Tre componenti: user agent mail server simple mail transfer protocol: smtp

Livello applicazione: (RFC), protocollo FTP, protocollo Posta Elettronica

La posta elettronica. Le code di ingresso e di uscita (1) Le code di ingresso e di uscita (2) SMTP

Esempi di applicazioni internet. WEB Trasferimento File Posta Elettronica Sistema dei nomi di dominio (DNS)

Università degli Studi di Bergamo

Application Layer FTP, SMTP, POP3, IMAP. Ricapitolando. porta 80. host or server. host or server. controlled by application developer process.

Livello applicazione: Sessioni HTTP, FTP, Posta Elettronica

Protocolli di applicazione

Reti di Calcolatori AA 2011/2012. Protocolli di applicazione. Livello di applicazione (2) Capitolo 2: Livello applicazione (2)

INFORMATICA DISTRIBUITA. lez 6 World Wide Web (cont)

Application Layer FTP, SMTP, POP3, IMAP

INFORMATICA DISTRIBUITA. prof. Carlo Bellettini. lez7 (cont)

Modulo 1: Posta elettronica

Parte II: Reti di calcolatori Lezione 8

Application Layer FTP, SMTP, POP3, IMAP. Ricapitolando. FTP: File Transfer Protocol [RFC 959] porta 80

D - ESERCIZI: Protocolli applicativi ed altro:

Livello applicazione: (RFC), protocollo FTP, protocollo Posta Elettronica, servizi di trasporto

Comunicazione remota asincrona

Capitolo 2 - parte 5. Corso Reti ed Applicazioni Mauro Campanella

Livello applicativo: (RFC), protocollo FTP, protocollo Posta Elettronica

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori (a.a. 2010/11)

Capitolo 2 - parte 5. Corso Reti ed Applicazioni Mauro Campanella Como 2003

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori I

Parte II: Reti di calcolatori Lezione 8 (32)

Il World Wide Web. Marco Porta - CIM: Web Design & Technologies

Network Address Translation (NAT)

Livello applicazione: (RFC), protocollo FTP, protocollo Posta Elettronica, servizi di trasporto

Livello di applicazione. Reti di Calcolatori. Corso di Laurea in Ingegneria Informatica. Livello di applicazione FTP, A.A.

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori I

Protocolli ARP e DHCP

Parte II: Reti di calcolatori Lezione 8 (32)

Reti di Calcolatori. Seconda lezione. Realizzato da Roberto Savino: 1

Reti di Calcolatori I. Prof. Roberto Canonico Dipartimento di Ingegneria Elettrica e delle Tecnologie dell Informazione

Livello applicativo. Obiettivi specifici: ! Protocolli specifici: " http " ftp " smtp " pop " dns " Programmazione di applicazioni

Reti di Telecomunicazione Lezione 7

Il livello trasporto: controllo di flusso in TCP

Esempi di programmi client/server in Python

Reti di Calcolatori I. Prof. Roberto Canonico Dipartimento di Ingegneria Elettrica e delle Tecnologie dell Informazione

Parte II: Reti di calcolatori Lezione 7

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori (a.a. 2010/11)

Casi pratici esempi. http smtp. Copyright Luciano Bononi 2004 (some figure credits to Kurose, Ross, Internet e reti di calcolatori)

Fondamenti di Internet e Reti

Il livello trasporto: introduzione Il protocollo UDP

Il Livello Applicazione

Applicazioni e protocolli application-layer

Condivisione file. FTP: modalità d uso

Che tipo di transport service è necessario per una applicazione? Protocolli application-layer (cont). Applicazioni e protocolli application-layer

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori I

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori I

Livello applicativo. Obiettivi generali: Obiettivi specifici: Protocolli specifici:

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori (a.a. 2011/12)

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori I

Applicazioni web. Sommario. Parte 4 http. http Metodi, intestazioni e codici di stato get post Parametri e cookie. Applicazioni web.

Fondamenti di Internet e Reti

Telematica II 13. Posta Elettronica

2.5. L'indirizzo IP identifica il computer di origine, il numero di porta invece identifica il processo di origine.

Parte II: Reti di calcolatori Lezione 9

SMSPortal. SMS-Gateway interfaccia SMTP. Versione , 2005, 2006 SMSPortal. Digitel Mobile Srl Via Raffaello, Pescara (Italy)

La posta elettronica

Il formato MIME. Che cosa è MIME?

Il formato MIME. Che cosa è MIME? Definizione base di MIME. Antonio Lioy - Politecnico di Torino ( ) 1. Antonio Lioy < polito.

Sistemi e Servizi di TLC. Lezione N. 8

Processi dell applicazione, socket e il sottostante protocollo di trasporto. Protocolli application-layer (cont).

Capitolo 16 I servizi Internet

Flavio De Paoli ITIS Lab

Metodologie Informatiche Applicate al Turismo

Corso di Laurea in Ingegneria delle Telecomunicazioni Corso di Reti di Calcolatori a.a. 2010/11 Antonio Pescapè

Introduzione alle Architetture di Rete

Programmazione in Rete

Il livello trasporto: Introduzione e protocollo UDP

Il livello trasporto: Introduzione e protocollo UDP

1999 Pier Luca Montessoro (si veda la nota di copyright alla slide n. 2) 1

Il servizio di posta elettronica

OSOR. Applicazioni di Rete

Teoria di un server di posta. Corso GNU/Linux Avanzato Torino,

INFORMATICA GENERALE - MODULO 2 CdS in Scienze della Comunicazione. CRISTINA GENA

Le Reti Informatiche

Informatica. Alfredo Cuzzocrea. Reti di Calcolatori

Ipertesto (testo + link a risorse)

Parte II: Reti di calcolatori Lezione 7 (31)

Progettazione Siti Web: Web

SMTP. Introduzione. Scambio di messaggi asincrono

RETI DI CALCOLATORI Home Work ritardi e livello applicativo

Protocolli Applicativi

4. Posta Elettronica ( )

Strato Applicazione. strato applicazione

Architettura dell Informazione

Servizi di rete e web. Prof. Maurizio Naldi A.A. 2015/16

Livello applicazione. Fondamenti di Informatica

SERVIZI INTERNET PARTE 2. SERVIZI DI RETE Storici

Parte II: Reti di calcolatori Lezione 9 (33)

Reti di Comunicazione e Internet

Content Delivery Networks (CDN)

Introduzione al corso

Transcript:

Corso di Laurea in Ingegneria Informatica Corso di Reti di Calcolatori (a.a. 2010/11) Roberto Canonico (roberto.canonico@unina.it) Giorgio Ventre (giorgio.ventre@unina.it) Protocolli applicativi: FTP ed SMTP 27 ottobre 2010 I lucidi presentati al corso sono uno strumento didattico che NON sostituisce i testi indicati nel programma del corso Nota di copyright per le slide COMICS Nota di Copyright Questo insieme di trasparenze è stato ideato e realizzato dai ricercatori del Gruppo di Ricerca COMICS del Dipartimento di Informatica e Sistemistica dell Università di Napoli Federico II. Esse possono essere impiegate liberamente per fini didattici esclusivamente senza fini di lucro, a meno di un esplicito consenso scritto degli Autori. Nell uso dovranno essere esplicitamente riportati la fonte e gli Autori. Gli Autori non sono responsabili per eventuali imprecisioni contenute in tali trasparenze né per eventuali problemi, danni o malfunzionamenti derivanti dal loro uso o applicazione. Autori: Simon Pietro Romano, Antonio Pescapè, Stefano Avallone, Marcello Esposito, Roberto Canonico, Giorgio Ventre Corso di Reti di Calcolatori 1

File Transfer Protocol (FTP) Internet oggi si presenta come una rete ad estensione globale che connette molti milioni di macchine sparse su tutto il globo. Spesso sorge l esigenza di copiare un file da una macchina ad un altra per poterlo utilizzare localmente: un documento di Office; un file eseguibile; un file di testo; etc Ciò può accadere sia tra macchine molto distanti tra di loro che tra macchine direttamente connesse, presenti nello stesso locale. 3 Il protocollo FTP Un apposito protocollo è stato definito a questo scopo. Si chiama File Transfer Protocol (FTP) Attraverso di esso è possibile trasferire uno o più files di qualsiasi tipo tra due macchine. Il protocollo FTP è descritto in RFC959 Lavora utilizzando due connessioni: una dati e una controllo (out of band) 4 Corso di Reti di Calcolatori 2

Come funziona FTP at host FTP interface FTP client local file system file transfer FTP Trasferisce files da o verso una macchina remota Usa il modello client/ client: è l entità che dà luogo al trasferimento (sia in un senso che nell altro) : è l entità remota che è in continua attesa di connessioni FTP da parte di altre entità ftp : numero di porto 21 5 Le connessioni di una sessione FTP Il client ftp contatta il ftp al porto 21; Vengono aperte due connessioni parallele: Controllo: scambio di comandi, messaggi di risposta tra il client e il (controllo out of band (fuori banda)) Dati: file che fluiscono dal client al o viceversa Un ftp mantiene uno stato, per es.: la directory corrente; i dati dell autenticazione. TCP control connection port 21 FTP client TCP data connection port 20 FTP 6 Corso di Reti di Calcolatori 3

Scambio delle informazioni I comandi vengono inviati come testo ASCII sulla connessione di controllo Anche le risposte sono costituite da testo ASCII NOTA: il testo ASCII è una sequenza di caratteri testuali stampabili 7 Esempi di comandi e codici Esempi di comandi: USER name PASS password LIST restituisce la lista dei files presenti nella directory corrente GET filename preleva il file dalla macchina remota PUT filename invia il file alla macchina remota Esempi di codici di stato: 331 Username OK, password required 125 data connection already open; transfer starting 425 Can t open data connection 452 Error writing file 8 Corso di Reti di Calcolatori 4

Un esempio 9 Cosa è un FTP Non è possibile per un client stabilire una connessione FTP verso una qualsiasi macchina Il tipo di paradigma adottato (client/) presuppone infatti che il debba essere stato opportunamente configurato per accettare connessioni Solitamente, per questioni di sicurezza, le macchine non sono configurate per accettare connessioni di tipo FTP; se si tenta di stabilire una connessione verso una macchina non abilitata la sessione fallisce e nessun trasferimento risulta possibile I client FTP sono invece disponibili pressocché su tutti i sistemi operativi di rete 10 Corso di Reti di Calcolatori 5

FTP passivo (1/2) Active FTP Il Client apre una connessione di controllo verso l indirizzo del sul porto 21 utilizzando un ephemeral port Il Server apre una connessione dati dal porto 20 verso il client Passive FTP Il Client apre una connessione di controllo verso l indirizzo del sul porto 21 utilizzando un ephemeral port Il Server sceglie un ephemeral port per la connessione dati e la comunica al Client Il Client apre la connessione dati sul porto indicato dal Nel caso passive FTP, è il client ad aprire una connessione verso il, sia per il canale di controllo che per il canale dati. FTP passivo (2/2) Active FTP Passive FTP Corso di Reti di Calcolatori 6

Il protocollo SMTP Una volta che una e-mail è stata scritta attraverso l uso di un programma su un personal computer, è necessario inviarla al destinatario Come è noto, il destinatario potrebbe non essere in quel momento disponibile ad accettare messaggi di posta: utente impegnato computer spento La posta elettronica sfrutta degli intermediari per il trasferimento delle e-mail tra le parti, alla stregua degli uffici postali che ospitano pacchi nell attesa che i destinatari passino a ritirarli Per trasferire messaggi di posta elettronica tra gli intermediari si utilizza un apposito protocollo Si chiama Simple Mail Transfer Protocol, definito in RFC821 13 Le entità in gioco Tre entità principali: s mail s protocollo SMTP User Agent anche detto mail reader composizione, modifica, lettura di messaggi es.: Eudora, Outlook, Mozilla Thunderbird, Evolution, Kmail messaggi in uscita ed in entrata immagazzinati sul Il protocollo SMTP viene utilizzato anche tra - e durante l invio di una mail mail SMTP mail SMTP SMTP mail outgoing message queue mailbox 14 Corso di Reti di Calcolatori 7

I mail Mail Server mailbox contenente messaggi in entrata (non letti) per l utente coda dei messaggi in uscita contenente i messaggi non ancora recapitati protocollo SMTP per l interazione tra due mail. client : mail mittente : mail destinatario Un mail funge in momenti diversi da client o da a seconda del ruolo che ricopre nello scambio del messaggio mail SMTP mail SMTP SMTP mail coda dei messaggi in uscita mailbox 15 Caratteristiche di SMTP (1) Usa il protocollo TCP (porto 25) per consegnare in modo affidabile messaggi dal client al Trasferimento diretto dal mittente al destinatario Tre fasi durante il trasferimento via SMTP: handshaking ( stretta di mano ) trasferimento del messaggio chiusura della connessione Interazione comando/risposta (command/response) comandi: testo ASCII risposta: codice di stato e descrizione (facoltativa) Messaggi codificati con caratteri ASCII a 7-bit 16 Corso di Reti di Calcolatori 8

Caratteristiche di SMTP (2) Usa una connessione persistente Richiede che il messaggio, comprensivo del contenuto, sia codificato in caratteri ASCII a 7 bit Alcune combinazioni di caratteri non sono ammesse (p.es., CRLF.CRLF). Quando queste combinazioni si presentano il messaggio deve essere opportunamente codificato. SMTP usa CRLF.CRLF per determinare la fine di un messaggio 17 Esempio di interazione client S: 220 hamburger.edu C: HELO crepes.fr S: 250 Hello crepes.fr, pleased to meet you C: MAIL FROM: <alice@crepes.fr> S: 250 alice@crepes.fr... Sender ok C: RCPT TO: <bob@hamburger.edu> S: 250 bob@hamburger.edu... Recipient ok C: DATA S: 354 Enter mail, end with "." on a line by itself C: Do you like ketchup? C: How about pickles? C:. S: 250 Message accepted for delivery C: QUIT S: 221 hamburger.edu closing connection 18 Corso di Reti di Calcolatori 9

SMTP in pratica: uso con telnet (1/2) telnet name 25 Si osservi il codice 220 di risposta dal Si inseriscano i comandi HELO, MAILFROM, RCPTTO, DATA, QUIT In questo modo è possibile inviare un e-mail senza servirsi dello 19 SMTP in pratica: uso con telnet (2/2) 20 Corso di Reti di Calcolatori 10

Formato del messaggio SMTP Linee di intestazione (header): To: From: Subject: differenti da comandi smtp! corpo (body): il messaggio vero e proprio solo caratteri ASCII header body linea vuota 21 L estensione MIME MIME: Multipurpose Internet Mail Extensions, RFC 2045-2056 righe aggiuntive nell intestazione informano della presenza di un body MIME versione MIME metodo utilizzato per codificare i dati tipo, sottotipo e parametri del contenuto dati codificati From: alice@crepes.fr To: bob@hamburger.edu Subject: Picture of yummy crepe. MIME-Version: 1.0 Content-Transfer-Encoding: base64 Content-Type: image/jpeg base64 encoded data.........base64 encoded data 22 Corso di Reti di Calcolatori 11

Messaggi SMTP: un esempio (sniffer Ethereal) 23 Esempi di tipi MIME Content-Type: type/subtype; parameters Text sottotipi: plain, html Image sottotipi: jpeg, gif Audio sottotipi: basic (8-bit mu-law encoded), 32kadpcm (32 kbps coding) Video sottotipi: mpeg, quicktime Application altri dati che devono essere processati da specifiche applicazioni sottotipi: msword, octet-stream 24 Corso di Reti di Calcolatori 12

Esempio di mail multiparte From: alice@crepes.fr To: bob@hamburger.edu Subject: Picture of yummy crepe. MIME-Version: 1.0 Content-Type: multipart/mixed; boundary=98766789 --98766789 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain Dear Bob, Please find a picture of a crepe. --98766789 Content-Transfer-Encoding: base64 Content-Type: image/jpeg base64 encoded data.........base64 encoded data --98766789-- 25 Prelievo della posta: Post Office Protocol (POP3) Fino ad ora abbiamo visto come sia possibile trasferire messaggi tra i vari mail Non abbiamo però ancora parlato di come un utente possa, in un momento qualsiasi, accedere alla propria casella di posta elettronica per leggere i propri messaggi Per questa operazione è previsto un ulteriore protocollo Esso è chiamato POP3 (Post Office Protocol versione 3) ed è definito in RFC 1939 Si tratta sempre di un protocollo client : lo ancora una volta gioca il ruolo di client POP il mail gioca il ruolo di POP 26 Corso di Reti di Calcolatori 13

La catena dei protocolli per la posta SMTP SMTP POP3 o IMAP mail mittente mail destinatario SMTP: consegna di messaggi Protocolli di accesso alla mail: recupero dei messaggi dai POP: Post Office Protocol autorizzazione ( ) e download IMAP: Internet Mail Access Protocol [RFC 2060] più complicato e potente manipolazione avanzata dei messaggi sul HTTP: gmail, Hotmail, Yahoo! Mail, ecc. 27 Esempio di dialogo POP3 autorizzazione comandi del client: : specifica la name pass: specifica la password il risponde +OK -ERR fase di scambio comandi del client: list: visualizza la lista dei messaggi retr: preleva il messaggio per numero dele: elimina il messaggio dal quit: chiude la sessione S: +OK POP3 ready C: alice S: +OK C: pass hungry S: +OK successfully logged on C: list S: 1 498 S: 2 912 S:. C: retr 1 S: <message 1 contents> S:. C: dele 1 C: retr 2 S: <message 1 contents> S:. C: dele 2 C: quit S: +OK POP3 signing off 28 Corso di Reti di Calcolatori 14

POP3 in pratica (1/2): telnet cds.unina.it 110 Qui c era la password! 29 POP3 in pratica (2/2): telnet cds.unina.it 110 30 Corso di Reti di Calcolatori 15

L accesso alla posta via WEB Molti siti web forniscono accesso alle proprie caselle di posta (gmail,hotmail, Yahoo!, ecc.) In questo caso non serve avere uno installato e correttamente configurato per ricevere ed inviare posta. È sufficiente disporre di un qualsiasi browser INTERNET POP3 SMTP HTTP browser mail destinatario web 31 Corso di Reti di Calcolatori 16