Creare una applicazione Winsock di base



Documenti analoghi
Laboratorio di Programmazione in Rete

Una prima applicazione in C per l utilizzo delle socket

Introduzione alla programmazione C di socket

Interazione (TCP) Client-Server con le socket

Esercitazione [6] Client/Server con Socket

DATAGRAM SOCKET. Angelastro Sergio Diomede Antonio Viterbo Tommaso

TECN.PROG.SIST.INF. UDP socket in Windows. Roberta Gerboni

L uso di Socket UDP. Usiamo le API Winsock incluse in <Winsock.h> A.A. 2005/06. Dott.ssa Valeria Carofiglio

Cenni di programmazione distribuita in C++ Mauro Piccolo

Interazione (TCP) Client-Server con le socket

I Socket. Laboratorio Software M. Grotto R. Farina

Laboratorio di Programmazione in rete

Laboratorio di Programmazione in Rete

Laboratorio di Programmazione in Rete

Socket TCP. prima parte

Opzioni per le Socket

Socket. Nei sistemi operativi moderni i servizi disponibili in rete si basano principalmente sul modello client/server.

Reti (già Reti di Calcolatori )

L uso di Socket UDP. TCP vs. UDP UDP

Una semplice applicazione client/server 1

Paradigma client-server

Laboratorio di Sistemi Operativi Cognome Nome Mat.

COMUNICAZIONE TRA PROCESSI REMOTI IN UNIX

IPC Inter Process Communication

Scrittura dei programmi applicativi di rete

I/O su Socket TCP: read()

Esercitazione [7] Client/Server con Socket

Socket TCP. seconda parte

Socket. Nei sistemi operativi moderni i servizi disponibili in rete si basano principalmente sul modello client/server.

RETI DI CALCOLATORI. Prof. PIER LUCA MONTESSORO Ing. DAVIDE PIERATTONI. Facoltà di Ingegneria Università degli Studi di Udine

Controllo Winsock di Visual Basic

Introduzione alle applicazioni di rete

Laboratorio di Programmazione in Rete

Esempio 1: stampa locale di file remoto

Program m azione di Sistem a 6

L interfaccia socket

Esercitazione Laboratorio di Sistemi Operativi Cognome Nome Mat.

10.1. Un indirizzo IP viene rappresentato in Java come un'istanza della classe InetAddress.

HTTP adaptation layer per generico protocollo di scambio dati

Programmazione di Rete

Scrittura dei programmi applicativi di rete

TECN.PROG.SIST.INF. TCP socket in Windows Roberta Gerboni

Programmazione socket. Queste slide sono distribuite con licenza Creative Commons Attribuzione-Non commerciale-condividi allo stesso modo 2.

INTERNET DOMAIN SOCKETS (Cap.59)

Programmazione dei socket con TCP #2

(VHUFLWD]LRQLGLEDVHVXOOH6RFNHWLQ&

C UDP in Windows p53 - variante 1

Socket per TCP: Fondamenti

Inizializzazione degli Host. BOOTP e DHCP

La programmazione di rete

Il client deve stampare tutti gli eventuali errori che si possono verificare durante l esecuzione.

Esercizio 2. Client e server comunicano attraverso socket TCP

Introduzione alla programmazione in C

TECNOLOGIE E PROGETTAZIONE DI SISTEMI INFORMATICI E DI TELECOMUNICAZIONI

Sistemi di Elaborazione. Introduzione alla Programmazione distribuita

1. RETI INFORMATICHE CORSO DI LAUREA IN INGEGNERIA INFORMATICA SPECIFICHE DI PROGETTO A.A. 2013/ Lato client

Transmission Control Protocol

Luca Mari, Sistemi informativi applicati (reti di calcolatori) appunti delle lezioni. Architetture client/server: applicazioni client

Esercizi (1-2): da: TCP/IP Sockets in C (Donahoo-Calvert)

J+... J+3 J+2 J+1 K+1 K+2 K+3 K+...

Altri tipi di connessione

Corso di Reti di Calcolatori T

Esercitazione [5] Input/Output su Socket

Tesina esame Programmazione di Sistemi Mobile realizzata da Roberto Giuliani matricola Sockets e DatagramSocket

rsystem Maximiliano Marchesi

Inizializzazione, Assegnamento e Distruzione di Classi

Telematica II 12. Esercitazione/Laboratorio 4

I.I.S. G.B. PENTASUGLIA MATERA ISTITUTO TECNICO SETTORE TECNOLOGICO LICEO SCIENTIFICO SCIENZE APPLICATE. Classe: 5Ci

Implementazione di un server. Server iterativo. Offro servizio ad un client alla volta. Dobbiamo scrivere un programma in C che offre un servizio

Strutture. Strutture e Unioni. Definizione di strutture (2) Definizione di strutture (1)

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

Reti di Telecomunicazioni Mobile IP Mobile IP Internet Internet Protocol header IPv4 router host indirizzi IP, DNS URL indirizzo di rete

Laboratorio di. Reti Informatiche. Corso di Laurea Triennale in Ingegneria Informatica A.A. 2016/2017. Ing. Niccolò Iardella

Elementi di programmazione con interfaccia Socket

Le funzioni in C. I programmi C sono costituiti da definizioni di variabili e funzioni.

Introduzione al Linguaggio C

Gestione dei File in C

LABORATORIO di Reti di Calcolatori

Guida all' uso dei sockets nella programmazione in C

Socket & RMI Ingegneria del Software - San Pietro

appunti delle lezioni Architetture client/server: applicazioni client

MODELLO CLIENT/SERVER. Gianluca Daino Dipartimento di Ingegneria dell Informazione Università degli Studi di Siena

Programmazione di applicazioni di rete

Socket Programming. Socket Programming. Università di Palermo

Applicazioni distribuite. La programmazione di rete. Interfacce e protocolli. Protocollo applicativo

Reti di Telecomunicazione Lezione 8

Funzioni in C. Violetta Lonati

Reti di Telecomunicazione Lezione 6

Laboratorio reti AA 2008/2009. Dott. Matteo Roffilli Ricevimento in ufficio dopo la lezione

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

Comunicazioni fra processi remoti: i socket nello UNIX di Berkeley

Esercitazione [08] Server multi-process/multi-thread

Esercitazione [7] Server multi-process/multi-thread

Record in C: il costruttore struct.

P2-11: BOOTP e DHCP (Capitolo 23)

SC per Inter Process Comminication. Comunicazione fra macchine diverse: socket

LABORATORIO di Reti di Calcolatori

Transcript:

Creare una applicazione Winsock di base Usiamo le API Winsock incluse in <Winsock.h>

Creare un progetto per una Socket Windows (in Dev C++) Selezionare la file New Projects Selezionare Empty Project Salvare il progetto in

Aggiungere la libreria Winsock al progetto (in Dev C++) Click su parametri Aggiungi libreria o oggetto Naviga nella directory Dev-C++\Lib e aggiungi il file libwsock32 (oppure libws2_32 per Winsock2) NB: I nomi delle librerie possono cambiare a seconda del compilatore Es: Visual C++ wsock32.lib (ws2_32.lib)

Applicazione di base #include<stdio.h> #include<winsock.h> void main() { return; } Input/output Standard (es: printf() ) API winsock

Inizializzazione dell applicazione Tutte le applicazioni Winsock devono essere inizializzate per essere sicuri che le socket windows siano supportate dal sistema Per inizializzare Winsock: Creare un elemento di tipo WSADATA: WSADATA wsadata; La struttura WSADATA contiene informazioni sull implementazione delle socket windows

Inizializzazione dell applicazione Tutte le applicazioni Winsock devono essere inizializzate per essere sicuri che le socket windows siano supportate dal sistema Per inizializzare Winsock: Creare un elemento di tipo WSADATA: WSADATA wsadata; La struttura WSADATA contiene informazioni sull implementazione delle socket windows typedef struct WSAData { wversion: versione per WORD wversion; la specifica di socket WORD whighversion; utilizzata whighversion: versione massima supportabile per la specifica di socket windows char szdescription[wsadescription_len+1]; char szsystemstatus[wsasys_status_len+1]; unsigned short imaxsockets; unsigned short imaxudpdg; char FAR* lpvendorinfo; } WSADATA

Inizializzazione dell applicazione Tutte le applicazioni Winsock devono essere inizializzate per essere sicuri che le socket windows siano supportate dal sistema Per inizializzare Winsock: Creare un elemento di tipo WSADATA: WSADATA wsadata; Specificare la versione di socket windows richiesta e recuperare i dettagli dell implementazione della socket windows specifica Int iresult = WSAStartup(MAKEWORD(2,2), &wsadata); If (iresult!= NO_ERROR) printf( error at WSASturtup\n );

Inizializzazione dell applicazione Tutte le applicazioni Winsock devono essere inizializzate per essere sicuri che le socket windows siano supportate dal sistema Per inizializzare Winsock: Creare un elemento di tipo WSADATA: WSADATA wsadata; Specificare la versione di socket windows richiesta e recuperare i dettagli dell implementazione della socket windows specifica Int iresult = WSAStartup(MAKEWORD(2,2), &wsadata); If (iresult!= NO_ERROR) printf( error at WSASturtup\n ); wversionrequested: versione di socket windows che il chiamante può usare. int WSAStartup( WORD wversionrequested, LPWSADATA lpwsadata ); Restituisce 0 in caso di successo. Il codice di errore altrimenti lpwsadata : puntatore alla struttura WSDATA che contiene informazioni per l implementazione della socket

Inizializzazione dell applicazione Tutte le applicazioni Winsock devono essere inizializzate per essere sicuri che le socket windows siano supportate dal sistema Per inizializzare Winsock: Creare un elemento di tipo WSADATA: WSADATA wsadata; Specificare la versione di socket windows richiesta e recuperare i dettagli dell implementazione della socket windows specifica Int iresult = WSAStartup(MAKEWORD(2,2), &wsadata); If (iresult!= NO_ERROR) printf( error at WSASturtup\n ); specifica il numero di versione di winsock sul sistema e lo costruisce correttamente

WORD wversionrequested; WSADATA wsadata; int err; wversionrequested = MAKEWORD( 2, 2 ); un esempio di codice err = WSAStartup( wversionrequested, &wsadata ); if ( err!= 0 ) { /* Tell the user that we could not find a usable */ /* WinSock DLL. */ return; } /* Confirm that the WinSock DLL supports 2.2.*/ /* Note that if the DLL supports versions greater */ /* than 2.2 in addition to 2.2, it will still return */ /* 2.2 in wversion since that is the version we */ /* requested. */ if ( LOBYTE( wsadata.wversion )!= 2 HIBYTE( wsadata.wversion )!= 2 ) { /* Tell the user that we could not find a usable */ /* WinSock DLL. */ WSACleanup( ); return; } /* The WinSock DLL is acceptable. Proceed. */ Inizializzazione dell applicazione

Interazione TCP Client/Server 2 2 Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare un local address alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione socket() Crea una socket dedicata ad un fornitore di servizi specifico SOCKET socket( int af, int type, int protocol ); Tipo SOCK_STREAM SOCK_DGRAM Address family (AF_INET: Internet Address Family) Significato Tipo di socket Fornisce una connessione sequenziale, affidabile e full-duplex. Il protocollo TCP è basato su questo tipo di socket. Supporta i datagrammi (privo di connessione, messaggi inaffidabili di una lunghezza massima prefissata). Il protocollo UDP è basato su questo tipo di socket. Protocollo da usare con la socket per l address family indicata (solitamente posto a 0 indica il protocollo derivato dalla coppia [af, type])

Funzione socket(): valori di ritorno Crea una socket dedicata ad un fornitore di servizi specifico SOCKET socket( int af, int type, int protocol ); La funzione restituisce un intero che è interpretato come un descrittore che referenzia la nuova socket in caso di successo. Altrimenti restituisce un codice di errore

Funzione socket(): valori di ritorno Crea una socket dedicata ad un fornitore di servizi specifico SOCKET socket( int af, int type, int protocol ); La funzione restituisce un intero che è interpretato come un descrittore che referenzia la nuova socket in caso di successo. Altrimenti restituisce un codice di errore ATTENZIONE!!! Una applicazione client usa indirizzo IP e porta per connettersi La funzione crea un socket senza nome Bind() Address Family Indirizzo IP Porta che identifica l applicazione

Creazione della socket Dopo l inizializzazione, deve essere creato un elemento di tipo socket Per creare una socket: Creare un elemento di tipo socket chiamato m_socket: SOCKET m_socket; Chiamare la funzione socket(). Il valore di ritorno è assegnato alla variabile m_socket m_socket: m_socket = socket(af_inet, SOCK_STREAM, IPPROTO_TCP);

Creazione della socket Dopo l inizializzazione, deve essere creato un elemento di tipo socket Per creare una socket: Creare un elemento di tipo socket chiamato m_socket: SOCKET m_socket; Chiamare la funzione socket(). Il valore di ritorno è assegnato alla variabile m_socket m_socket: m_socket = socket(af_inet, SOCK_STREAM, IPPROTO_TCP); In questo esempio la funzione usa l internet address family, con socket di tipo stream e protocollo TCP/IP (? 0 )

Creazione della socket Dopo l inizializzazione, deve essere creato un elemento di tipo socket Per creare una socket: Creare un elemento di tipo socket chiamato m_socket: SOCKET m_socket; Chiamare la funzione socket(). Il valore di ritorno è assegnato alla variabile m_socket m_socket: m_socket = socket(af_inet, SOCK_STREAM, IPPROTO_TCP); Valutare la presenza di errori per assicurarsi che la socket sia valida if ( m_socket == INVALID_SOCKET ) { printf( "Error at socket(): %ld\n", WSAGetLastError() ); WSACleanup(); return; }

Funzione socket(): gestione dell errore Crea una socket dedicata ad un fornitore di servizi specifico SOCKET socket( int af, int type, int protocol ); Esempi di errori. L MSDN fornisce descrizioni di questo tipo per tutte le funzioni

Interazione TCP Client/Server 3 2 Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare un local address alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione bind() Associa un nome alla socket creata in precedenza int bind( SOCKET s, const struct sockaddr* name, int namelen); Descrittore di un socket Indirizzo da assegnare alla socket Lunghezza in byte di name

Struttura sockaddr_in La struttura sockaddr è interpretata differentemente a seconda dei contesti determinati dalle differenti address family (AF_XXXX). Forma di sockaddr In AF_INET (con protocollo IPv4) struct sockaddr_in { short sin_family; u_short sin_port; struct in_addr sin_addr; char sin_zero[8]; }; Un puntatore ad una sockaddr non è rigorosamente interpretato come tale Le funzioni Winsock che fanno uso di un puntatore ad una struttura di tipo sockaddr devono necessariamente effettuare una operazione di cast bind( m_socket, (SOCKADDR*) &service, sizeof(service)

Funzione bind(): valori di ritorno Associa un nome alla socket creata in precedenza int bind( SOCKET s, const struct sockaddr* name, int namelen); La funzione restituisce O in caso di successo. Altrimenti restituisce un codice di errore Per il TCP/IP se la porta è specificata come zero, il fornitore di servizi assegna una porta tra 1024 e 5000 L applicazione può usare la funzione getsockname (dopo la bind) per apprendere l indirizzo IP e la porta assegnati

Assegnare una porta alla socket (lato server) Sockaddr_in service; Dopo la creazione di una socket Per assegnare una porta ed un indirizzo IP alla socket Creare un elemento di tipo sockaddr_in chiamato service:

Assegnare una porta alla socket (lato server) Sockaddr_in service; Dopo la creazione di una socket Per assegnare una porta ed un indirizzo IP alla socket Creare un elemento di tipo sockaddr_in chiamato service: Porta TCP UDP Non Usato struct sockaddr_in { short sin_family; u_short sin_port; struct in_addr sin_addr; char sin_zero[8]; }; struct in_addr { unsigned long s_addr; }; Address family (AF_XXXX) Indirizzo IP Indirizzi internet 32 bit

Assegnare una porta alla socket (lato server) Sockaddr_in service; Dopo la creazione di una socket Per assegnare una porta ed un indirizzo IP alla socket Creare un elemento di tipo sockaddr_in chiamato service: Avvalorare l elemento creato service.sin_family = AF_INET; service.sin_addr.s_addr = inet_addr( "127.0.0.1" ); service.sin_port = htons( 27015 ); Local address

Assegnare una porta alla socket (lato server) Sockaddr_in service; Dopo la creazione di una socket Per assegnare una porta ed un indirizzo IP alla socket Creare un elemento di tipo sockaddr_in chiamato service: Avvalorare l elemento creato service.sin_family = AF_INET; service.sin_addr.s_addr = inet_addr( "127.0.0.1" ); service.sin_port = htons( 27015 ); Assegnare porta e Ip alla socket. Valutare errori if ( bind( m_socket, (SOCKADDR*) &service, sizeof(service) ) == SOCKET_ERROR ) { printf( "bind() failed.\n" ); closesocket(m_socket); return; }

Funzione bind(): gestione dell errore Crea una socket dedicata ad un fornitore di servizi specifico int bind( SOCKET s, const struct sockaddr* name, int namelen);

#include <stdio.h> #include "winsock2.h" un esempio di codice void main() { // Initialize Winsock WSADATA wsadata; int iresult = WSAStartup(MAKEWORD(2,2), &wsadata); if (iresult!= NO_ERROR) printf("error at WSAStartup()\n"); // Create a SOCKET for listening for incoming connection requests SOCKET ListenSocket; ListenSocket = socket(af_inet, SOCK_STREAM, IPPROTO_TCP); if (ListenSocket == INVALID_SOCKET) { printf("error at socket(): %ld\n", WSAGetLastError()); WSACleanup(); return; } // The sockaddr_in structure specifies the address family, IP address, and port for the socket that //is being bound. sockaddr_in service; service.sin_family = AF_INET; service.sin_addr.s_addr = inet_addr("127.0.0.1"); service.sin_port = htons(27015);

un esempio di codice (cont.) // Bind the socket. if (bind( ListenSocket, (SOCKADDR*) &service, sizeof(service)) == SOCKET_ERROR) { printf("bind() failed.\n"); closesocket(listensocket); return; } } WSACleanup(); return;

Interazione TCP Client/Server 3 2 Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare una porta alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione listen() Setta la socket in uno stato in cui rimane in attesa di richiesta di connessioni int listen( SOCKET s, int backlog); Descrittore di una socket Massima lungezza della coda di connessioni entranti

Funzione listen(): valori di ritorno Setta la socket in uno stato in cui rimane in attesa di richiesta di connessioni int listen( SOCKET s, int backlog); Descrittore di una socket Massima lungezza della coda di connessioni entranti La funzione restituisce O in caso di successo. Altrimenti restituisce un codice di errore

Settare la socket all ascolto (lato server) Il server deve essere in grado di ascoltare una richiesta di connessione Per settare l ascolto Chiamare la funzione listen(), passando come parametri la socket creata e il massimo numero di connessioni che accetta if ( listen( m_socket, 1 ) == SOCKET_ERROR ) printf( "Error listening on socket.\n");

Funzione listen(): gestione dell errore Crea una socket dedicata ad un fornitore di servizi specifico int listen( SOCKET s, int backlog);

Interazione TCP Client/Server 4 2 Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare una porta alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione accept() Consente un tentativo di connessione in entrata su una socket SOCKET accept( SOCKET s, struct sockaddr* addr, int* addrlen); Descrittore di una socket Puntatore opzionale ad un buffer che riceve l indirizzo dell entità che fa richiesta di connessione Puntatore opzionale che contiene la lunghezza di addr

Funzione accept() Consente un tentativo di connessione in entrata su una socket SOCKET accept( SOCKET s, struct sockaddr* addr, int* addrlen); La funzione estrae la prima connessione dalla coda di pendenza delle connessioni sul socket s. Successivamente crea e restituisce un riferimento ad unanuova socket. Questa nuova socket è quella che abbiamo chiamato socket di connessione. Mantiene le stesse prorpieta della socket s

Accettare una nuova connessione (lato server) Una volta in ascolto, il server deve essere in grado di gestire le richieste di nuove connessioni Per accettare una connessione su una socket Creare un elemento temporaneo di tipo SOCKET temporaneo SOCKET AcceptSocket;

Accettare una nuova connessione (lato server) Una volta in ascolto, il server deve essere in grado di gestire le richieste di nuove connessioni Per accettare una connessione su una socket Creare un elemento temporaneo di tipo SOCKET temporaneo SOCKET AcceptSocket; Effettuare un ciclo continuo per determinare se ci sono richieste di connessione e chiamare la funzione Accept() per accettare eventuali connessioni printf( "Waiting for a client to connect...\n" ); while (1) { AcceptSocket = SOCKET_ERROR; while ( AcceptSocket == SOCKET_ERROR ) { AcceptSocket = accept( m_socket, NULL, NULL ); }

Funzione accept():gestione dell errore Consente un tentativo di connessione in entrata su una socket SOCKET accept( SOCKET s, struct sockaddr* addr, int* addrlen);

Accettare una nuova connessione (lato server) Una volta in ascolto, il server deve essere in grado di gestire le richieste di nuove connessioni Per accettare una connessione su una socket SOCKET AcceptSocket; printf( "Waiting for a client to connect...\n" ); while (1) { AcceptSocket = SOCKET_ERROR; while ( AcceptSocket == SOCKET_ERROR ) { AcceptSocket = accept( m_socket, NULL, NULL ); } Quando la connessione del client è stata accettata: trasferire il controllo dal socket temporanea a quella originale e interrompere la ricerca di nuove connessioni printf( "Client Connected.\n"); m_socket = AcceptSocket; break; }

Interazione TCP Client/Server 4 3 Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare una porta alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione connect() Stabilisce una connessione ad una socket specificata int connect( SOCKET s, const struct sockaddr* name, int namelen); Descrittore di un socket non connesso Nome della socket con cui dovrebbe essere stabilita la connessione lunghezza di name

Funzione connect() Stabilisce una connessione ad una socket specificata int connect( SOCKET s, const struct sockaddr* name, int namelen); Per una socket di tipo connectionless (per esempio SOCK_DGRAM), la connect() semplicemente stabilisce un indirizzo di destinazione di default Qualunque datagram ricevuto da un indirizzo diverso da quello di destinazione verrà scaricato Se il campo indirizzo della struttura che specifica il name è zero, la socket verrà disconnessa

Connettersi al Server (lato client) Affinchè un client possa comunicare con un server, si deve connettere al server Per connettersi ad un server Creare un elemento di tipo sockaddr_in (ClientService) e settare il suo valore sockaddr_in clientservice; clientservice.sin_family = AF_INET; clientservice.sin_addr.s_addr = inet_addr( "127.0.0.1" ); clientservice.sin_port = htons( 27015 );

Connettersi al Server (lato client) Affinchè un client possa comunicare con un server, si deve connettere al server Per connettersi ad un server Creare un elemento di tipo sockaddr_in (ClientService) e settare il suo valore sockaddr_in clientservice; clientservice.sin_family = AF_INET; clientservice.sin_addr.s_addr = inet_addr( "127.0.0.1" ); clientservice.sin_port = htons( 27015 ); Chiamare la funzione connect () passando come parametri la socket creata e settata all ascolto e la struttura sockaddr_in. Verificare la presenza di errori if ( connect( m_socket, (SOCKADDR*) &clientservice, sizeof(clientservice) ) == SOCKET_ERROR) { printf( "Failed to connect.\n" ); WSACleanup(); return; }

Funzione connect():gestione dell errore Stabilisce una connessione ad una socket specificata int connect( SOCKET s, const struct sockaddr* name, int namelen);

Funzione connect():gestione dell errore(cont.) Stabilisce una connessione ad una socket specificata int connect( SOCKET s, const struct sockaddr* name, int namelen);

#include <stdio.h> #include "winsock2.h" void main() { un esempio di codice // Initialize Winsock WSADATA wsadata; int iresult = WSAStartup(MAKEWORD(2,2), &wsadata); if (iresult!= NO_ERROR) printf("error at WSAStartup()\n"); // Create a SOCKET for connecting to server SOCKET ConnectSocket; ConnectSocket = socket(af_inet, SOCK_STREAM, IPPROTO_TCP); if (ConnectSocket == INVALID_SOCKET) { printf("error at socket(): %ld\n", WSAGetLastError()); WSACleanup(); return; }

un esempio di codice (cont.) // The sockaddr_in structure specifies the address family, // IP address, and port of the server to be connected to. sockaddr_in clientservice; clientservice.sin_family = AF_INET; clientservice.sin_addr.s_addr = inet_addr( "127.0.0.1" ); clientservice.sin_port = htons( 27015 ); // Connect to server. if ( connect( ConnectSocket, (SOCKADDR*) &clientservice, sizeof(clientservice) ) == SOCKET_ERROR) { printf( "Failed to connect.\n" ); WSACleanup(); return; } printf("connected to server.\n"); WSACleanup(); return; }

Interazione TCP Client/Server Server 1. (Inizializzare una WSA) 2. Creare una socket 3. Assegnare un local address alla socket 4. Settare la socket all ascolto 5. Iterativamente: a. Accettare una nuova connessione b. Inviare e ricevere dati c. Chiudere la connessione Client 1. (Inizializzare una WSA) 2. Creare una Socket 3. Connettersi al server 4. Inviare e ricevere dati 5. Chiudere la connessione

Funzione send() Invia dati ad una socket connessa int send( SOCKET s, const char* buf, int len, int flags ); Descrittore di una socket connessa Puntatore al Buffer contenente I dati da trasmettere Indicatore che specifica il modo in cui la chiamata è fatta Lunghezza dei dati in buf, in byte Il flag può essere usato per influenzare il comportamento della funzione

Funzione send(): valori di ritorno Invia dati ad una socket connessa int send( SOCKET s, const char* buf, int len, int flags ); Descrittore di una socket connessa Buffer contenente I dati da trasmettere Indicatore che specifica il modo in cui la chiamata è fatta Lunghezza dei dati in buf, in byte Il flag può essere usato per influenzare il comportamento della funzione La funzione restituisce il numero di byte trasmessi in caso di successo. Un codice di errore, altrimenti

Funzione recev() Riceve dati da una socket connessa (o legata ) int recev(socket s, char* buf, int len, int flags ); Descrittore di una socket connessa Puntatore al Buffer contenente I dati da ricevere Indicatore che specifica il modo in cui la chiamata è fatta Lunghezza dei dati in buf, in byte Il flag può essere usato per influenzare il comportamento della funzione

Per inviare e ricevere dati Inviare e ricevere dati (lato Server) int bytessent; int bytesrecv = SOCKET_ERROR; char sendbuf[32] = "Server: Sending Data."; char recvbuf[32] = ""; bytesrecv = recv( m_socket, recvbuf, 32, 0 ); printf( "Bytes Recv: %ld\n", bytesrecv ); bytessent = send( m_socket, sendbuf, strlen(sendbuf), 0 ); printf( "Bytes Sent: %ld\n", bytessent ); Due interi sono usati per tenere traccia del numero di byte che vengono inviati e ricevuti.

Per inviare e ricevere dati Inviare e ricevere dati (lato Client) int bytessent; int bytesrecv = SOCKET_ERROR; char sendbuf[32] = "Client: Sending data."; char recvbuf[32] = ""; bytessent = send( m_socket, sendbuf, strlen(sendbuf), 0 ); printf( "Bytes Sent: %ld\n", bytessent ); if ( bytesrecv == 0 (bytesrecv == SOCKET_ERROR && WSAGetLastError()== WSAECONNRESET )) { bytesrecv = recv( m_socket, recvbuf, 32, 0 ); if ( bytesrecv == -1 ) { printf( "Connection Closed.\n"); break; } if (bytesrecv < 0) return; printf( "Bytes Recv: %ld\n", bytesrecv ); } Due interi sono usati per tenere traccia del numero di byte che vengono inviati e ricevuti.

Funzione send():gestione dell errore Invia dati ad una socket connessa int send( SOCKET s, const char* buf, int len, int flags );

Funzione send():gestione dell errore(cont.) Invia dati ad una socket connessa int send( SOCKET s, const char* buf, int len, int flags );

Funzione recev():gestione dell errore Riceve dati da una socket connessa (o legata ) int recev(socket s, char* buf, int len, int flags );

Funzione recev():gestione dell errore (cont.) Riceve dati da una socket connessa (o legata ) int recev(socket s, char* buf, int len, int flags );