From 97916409eb9cdaf9b4f6ed12a5693c5e6f3ee0d8 Mon Sep 17 00:00:00 2001 From: Ludovic Pouzenc Date: Sat, 22 Jan 2011 17:14:23 +0000 Subject: Version du C qui compile et qui accepte des clients git-svn-id: file:///var/svn/2011-usi/trunk@11 db941bf7-0cb3-4dda-9634-87faf64f93a7 --- app/v3_c/src/myhttpd.c | 37 +++++++++++++++++++++++++++++++++---- 1 file changed, 33 insertions(+), 4 deletions(-) (limited to 'app/v3_c/src/myhttpd.c') diff --git a/app/v3_c/src/myhttpd.c b/app/v3_c/src/myhttpd.c index d662dd3..1e0c3e8 100644 --- a/app/v3_c/src/myhttpd.c +++ b/app/v3_c/src/myhttpd.c @@ -5,17 +5,46 @@ #include #include +#include #include #include "myhttpd.h" +#include "utils.h" int main() { - //int res; - - int sockServ; + int res; + int sockServ, sockCli; + struct sockaddr_in servAddr, cliAddr; + size_t cliAddrLen; + int ending; + // Création socket sockServ = socket(AF_INET, SOCK_STREAM, 0); - if (sockServ -1) { perror("socket"); exit(1); } + if (sockServ < 0) { perror("socket"); exit(1); } + + // Accrochage du socket (adresse et port locaux) + bzero((char *) &servAddr, sizeof(servAddr)); + servAddr.sin_family = AF_INET; + servAddr.sin_addr.s_addr = INADDR_ANY; + servAddr.sin_port = htons(LISTEN_PORT); + res=bind(sockServ, (struct sockaddr *) &servAddr, sizeof(servAddr)); + if (res < 0) { perror("bind"); exit(2); } + + // On la:nce l'écoute + listen(sockServ,LISTEN_BACKLOG); + if (res < 0) { perror("listen"); exit(3); } + + // Boucle d'acceptation des clients + cliAddrLen = sizeof(cliAddr); + ending=0; + while ( ! ending ) { + sockCli=accept(sockServ, (struct sockaddr *) &cliAddr, &cliAddrLen); + #ifdef DEBUG + logs("Client accepté"); + #endif + + } return 0; } + -- cgit v1.2.3