salut,

en jouant avec les socket (et les winsocks (berk)), j'arrive à un
résultat assez surprenant... je vous fait voir...

binny@typhus:~$ ./rzo_server 44444
SERVEUR> Le serveur ecoute le port 44444
192.168.0.2:32772 [1]   : d
192.168.0.2:32772 [2]   : ee
192.168.0.2:32772 [1]   : de
SERVEUR> Arret du serveur (signal 2)

et en meme temps
binny@storia:~/tauceti/tauceti/client/functions$ ./rzo_test 
ENVOI : d
REPONSE : d
ENVOI : ee
REPONSE : ee
ENVOI : d
REPONSE : de

d'ou peut venir ce problème des lettres qui restent ?

Le code du serveur est en C et celui du client en C++.

Je mets en attachement les fichiers sources...

merci de jeter un oeil

@+,
binny

ps: faites pas trop attention, je code comme un goret :)
ps2: si vous connaissez un bon tutorial/livre/autre sur les winsocks et
les sockets, je suis preneur... fr/en

-- 

Un coup de chaleur ? Passez sur La Banquise... 
http://www.labanquise.org

       Benjamin Michotte        <[EMAIL PROTECTED]>
  °v°  web      : http://www.baby-linux.net
  _o_  homepage : http://www.baby-linux.net/binny
       slaktool : http://slaktool.sourceforge.net
       icq uin  : 99745024
#include "rzo.h"

int main(int argc, char **argv) {
        
        Rzo mon_rzo("typhus", 44444);
        
        string yop;

        while(1) {
                cout << "ENVOI : ";
                cin >> yop;
                mon_rzo.send(yop);
                cout << "REPONSE : " << mon_rzo.receive() << endl;
        }

}
/*
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Library General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *
 *  Start: Fri Aug 24 16:34:46 CEST 2001
 *     Benjamin Michotte (binny) <[EMAIL PROTECTED]>
 *  Filename: rzo.cxx
 *
 */

#include "rzo.h"

Rzo::Rzo(char *serveur, int port) {
        
        nom_serveur = new char[strlen(serveur)+1];
        strcpy(nom_serveur, serveur);
        numero_port_serveur = port;

#ifdef _WIN32
        int error;
        
        version = MAKEWORD( 2, 0 );
        error = WSAStartup( version, &wsaData );
        if(error != 0) {
                exit(1); // see later for something better
        }
        if(LOBYTE(wsaData.wVersion) != 2 || HIBYTE(wsaData.wVersion) != 0) {
    WSACleanup();
    exit(1); // see later for something better
        }
#endif
        
        fd = socket(AF_INET, SOCK_DGRAM, 0);
        if(fd < 0) {
                cout << "oops... fuck, can't create the socket";
                exit(1);
        }
        
        hote = gethostbyname(nom_serveur);

#ifdef _WIN32
        memset(&adresse_socket_serveur, 0, sizeof adresse_socket_serveur);
#endif

        adresse_socket_serveur.sin_family = AF_INET;
        adresse_socket_serveur.sin_port = htons(numero_port_serveur);

#ifdef LINUX
        adresse_socket_serveur.sin_addr = *(struct in_addr *)hote->h_addr;
#elif _WIN32    
        adresse_socket_serveur.sin_addr.s_addr = ((struct in_addr 
*)(hote->h_addr))->s_addr;
        if(connect(fd, &adresse_socket_serveur, sizeof adresse_socket_serveur) == 
SOCKET_ERROR)
                return FALSE;
#endif

        if(hote == NULL) {
                cout << "oops... can't find server :(";
                exit(1);
        }
        
        taille_adresse_socket_serveur = sizeof adresse_socket_serveur;
}

Rzo::~Rzo() {

#ifdef LINUX
        close(fd);
#elif _WIN32
        closesocket(fd);
        WSACleanup();
#endif
}

bool Rzo::send(string word) {
        
        int longueur_requete = word.size();
        char *sendmsg = new char[longueur_requete];
        strcpy(sendmsg, word.data());

        if(sendto(fd, sendmsg, longueur_requete, 0, 
                                        (struct sockaddr *)&adresse_socket_serveur, 
                                        taille_adresse_socket_serveur) < 0)
                return false;

        delete sendmsg;
        return true;
}

string Rzo::receive(void) {
        
        char *creponse;
        creponse = (char*)malloc(TAILLE_TAMPON);
        int longueur_reponse = recvfrom(fd, 
                                                                                       
                                         creponse,
                                                                                       
                                         TAILLE_TAMPON,
                                                                                       
                                         0,
                                                                                       
                                         NULL,
                                                                                       
                                         0);

        string reponse(creponse);
        
        if(longueur_reponse < 0)
                return "oops... a fuckin' error";
        return reponse;

}
/*
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Library General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
 *
 *  Start: Fri Aug 24 16:34:55 CEST 2001
 *     Benjamin Michotte (binny) <[EMAIL PROTECTED]>
 *  Filename: rzo.h
 *
 */

#ifndef __RZO_H__
#define __RZO_H__

#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <string>

#ifdef LINUX
#include <sys/socket.h>
#include <netdb.h>
#include <unistd.h>
#elif _WIN32
// don't forget to add ws2_32.lib when compiling
#include <winsock2.h>
#endif

#ifndef EXIT_FAILURE
#define EXIT_FAILURE -1
#endif

#define TAILLE_TAMPON 1000

class Rzo {
        private:
                struct sockaddr_in adresse_socket_serveur;
#ifdef LINUX
                int fd;
#elif _WIN32
                SOCKET fd;
                WSADATA wsaData;
                WORD version;
#endif
                struct hostent *hote;
                int taille_adresse_socket_serveur;
                char *nom_serveur;
                int numero_port_serveur;

        public:
                Rzo(char*, int);
                ~Rzo();
                bool send(string);
                string receive(void);
};

#endif /* __RZO_H__ */
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <arpa/inet.h>
#include <ctype.h>

#define TAILLE_TAMPON 1000
static int fd;  

void ErreurFatale(char message[]) {
        printf("SERVEUR> Erreur fatale\n");
        perror(message); 
        exit(EXIT_FAILURE); 
}

void ArretServeur(int signal) {
        close(fd);
        printf("SERVEUR> Arret du serveur (signal %d)\n",signal);
        exit(EXIT_SUCCESS);
}

int main(int argc, char **argv) {
        struct sockaddr_in adresse_socket_serveur;
        size_t taille_adresse_socket_serveur;
        int numero_port_serveur;
        char *src, *dst;  
        struct sigaction a;
        
        if (argc != 2) {
                printf("usage: %s port\n",argv[0]);
                exit(1);
        };
        numero_port_serveur = atoi(argv[1]);
        
        a.sa_handler = ArretServeur;
        sigemptyset(&a.sa_mask); 
        a.sa_flags   = 0;
        sigaction(SIGINT,&a,NULL);
        
        fd = socket(AF_INET,SOCK_DGRAM,0);
        if(fd < 0) 
                ErreurFatale("socket");

        adresse_socket_serveur.sin_family      = AF_INET;    
        adresse_socket_serveur.sin_addr.s_addr = INADDR_ANY; 
        adresse_socket_serveur.sin_port        = htons(numero_port_serveur);
        
        taille_adresse_socket_serveur = sizeof adresse_socket_serveur;
        if(bind(fd, (struct sockaddr *)&adresse_socket_serveur, 
taille_adresse_socket_serveur) < 0) 
           ErreurFatale("bind");
        
        printf("SERVEUR> Le serveur ecoute le port %d\n", numero_port_serveur);
        
        while(1) {
                struct sockaddr_in adresse_socket_client;
                int taille_adresse_socket_client;
                char *tampon_requete;
                int longueur_requete;
                
                longueur_requete = 0;
                
                tampon_requete = (char*)malloc(TAILLE_TAMPON);
                                
                taille_adresse_socket_client = sizeof(adresse_socket_client);
                longueur_requete = recvfrom(fd,
                                                                                
tampon_requete,
                                                                                
TAILLE_TAMPON,
                                                                                0,
                                                                                
(struct sockaddr *)&adresse_socket_client,
                                                                                
(socklen_t *)&taille_adresse_socket_client);
                
                if(longueur_requete < 0) 
                        ErreurFatale("recfrom");
                
                printf("%s:%d [%d]\t: %s\n",
                                                
inet_ntoa(adresse_socket_client.sin_addr),
                                                ntohs(adresse_socket_client.sin_port),
                                                longueur_requete,
                                                tampon_requete);  
                
                if (sendto(fd,
                                        tampon_requete,
                                        longueur_requete,
                                        0,
                                        (struct sockaddr *)&adresse_socket_client,
                                        taille_adresse_socket_client) < 0) 
                        ErreurFatale("Envoi de la reponse");
                
                free(tampon_requete);
        }
}

Reply via email to