Application client seveur si simple en c et sous linux

Fermé
DevGl Messages postés 136 Date d'inscription samedi 23 novembre 2013 Statut Membre Dernière intervention 16 mai 2015 - Modifié par jipicy le 31/05/2014 à 21:57
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 - 3 juin 2014 à 20:10
Bonjour,
je voulais realise en programmation sockets une petite application de client serveur ,
sous linux j ai les 2 codes , un pour client , et l autre pour serveur , bon sous le terminal j ai pu compiler le code serveur , mais pour le code client ca marche pas , je recois plusieurs warning , et le code ne se compile pas :( , est ce que vous pouvez m aider a corriger les erreurs dans ce programme s il vous plait /
cette petite application est base sur le language C
le voila




#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>

void error(char *msg)
{
perror(msg);
exit(0);
}

int main(int argc, char *argv[])
{
int sockfd, portno, n;
struct sockaddr_in serv_addr;
struct hostent *server;

char buffer[256];

if (argc < 3)
{
fprintf(stderr,"usage %s hostname port\n", argv[0]);
exit(0);
}

portno = atoi(argv[2]);

sockfd = socket(AF_INET, SOCK_STREAM, 0);

if (sockfd < 0 )
{
              error("ERROR opening socket");
}

server = gethostbyname ( argv[1]);

if( server == NULL ) 
{
          fprintf(stderr ,"ERROR , no such host\n");
          exit(0);
}



bzero((char *) &serv_addr ,sizeof((serv_addr));
serv_addr.sin_family = AF_INET ;

bcopy ((char * )server->h_addr , (char * )&serv_addr.sin_addr.s_addr , server->h_length);


serv_addr.sin_port = htons(portno);

if (connect(sockfd,&serv_addr,sizeof(serv_addr)) < 0)
{
error("ERROR connecting");
}
printf("Please enter the message: ");
bzero(buffer,256);
fgets(buffer,255,stdin);
n = write(sockfd,buffer,strlen(buffer));
if (n < 0)
{
error("ERROR writing to socket");
}
bzero(buffer,256);
n = read(sockfd,buffer,255);
if (n < 0)
{
error("ERROR reading from socket");
}
printf("%s\n",buffer);

return 0;
}




et voila les warning :






client.c: In function 'error':
client.c:10:1: warning: incompatible implicit declaration of built-in function 'exit' [enabled by default]
 exit(0);
 ^
client.c: In function 'main':
client.c:24:1: warning: incompatible implicit declaration of built-in function 'exit' [enabled by default]
 exit(0);
 ^
client.c:41:11: warning: incompatible implicit declaration of built-in function 'exit' [enabled by default]
           exit(0);
           ^
client.c:46:1: warning: incompatible implicit declaration of built-in function 'bzero' [enabled by default]
 bzero((char *) &serv_addr ,sizeof((serv_addr));
 ^
client.c:46:47: error: expected ')' before ';' token
 bzero((char *) &serv_addr ,sizeof((serv_addr));
                                               ^
client.c:75:1: error: expected ';' before '}' token
 }
 ^
A voir également:

1 réponse

fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 844
1 juin 2014 à 00:22
Bonjour,

Tu as oublié : #include <stdlib.h>
Cela enlèvera les 3 premiers warnings.

Ensuite, en rajoutant : #include <string.h>, tu enlèveras le warning suivant.

Et enfin pour corriger l'erreur : bzero((char *) &serv_addr ,sizeof((serv_addr));
Tu as mis une parenthèse en trop => sizeof(serv_addr));

Sinon pour info, les exit(0); devraient plutôt être remplacés par des return EXIT_FAILURE;
atoi() est obsolète. Tu devrais plutôt utiliser strtol().

Cdlt,
0
[Dal] Messages postés 6203 Date d'inscription mercredi 15 septembre 2004 Statut Contributeur Dernière intervention 29 janvier 2025 1 098
Modifié par [Dal] le 3/06/2014 à 13:48
@fiddy, tu dis :

Sinon pour info, les exit(0); devraient plutôt être remplacés par des return EXIT_FAILURE;

Sauf celui qui est dans
void error(char *msg)
, qui devrait être
exit(EXIT_FAILURE);
.


Dal
0
fiddy Messages postés 11069 Date d'inscription samedi 5 mai 2007 Statut Contributeur Dernière intervention 23 avril 2022 1 844
3 juin 2014 à 20:10
Ah je ne l'avais pas vu lui. Bien vu :-)
0