351d9caa
Speedclocker
Ajout de serveur/...
|
1
2
3
4
5
|
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
|
351d9caa
Speedclocker
Ajout de serveur/...
|
6
7
8
|
#include <string.h>
#include <netdb.h>
#include <arpa/inet.h>
|
5940bf6e
skhinach
Quelques modifs
|
9
10
11
|
#include <pthread.h>
|
32c9271a
skhinach
modif
|
12
|
#include "libthrd.h"
|
685f1984
Speedclocker
Ajout threads
|
13
14
15
|
|
351d9caa
Speedclocker
Ajout de serveur/...
|
16
17
18
19
20
21
22
23
24
25
26
27
|
int initialisationServeur(char* service)
{
int sock_fd;
struct addrinfo precisions, *resultat=NULL, *origine; // On stocke dans précisions nos besoins pour le socket, dans resultat l'adresse qui respectera les reqêtes
memset(&precisions, 0, sizeof precisions);
precisions.ai_family = AF_UNSPEC;
precisions.ai_socktype = SOCK_STREAM;
precisions.ai_flags = AI_PASSIVE;
if(getaddrinfo(NULL, service, &precisions, &origine)<0) { fprintf(stderr, "Erreur getaddrinfo\n"); return(-1); }
|
8450f712
Antoine Moreau
fin
|
28
|
|
351d9caa
Speedclocker
Ajout de serveur/...
|
29
30
|
for(struct addrinfo* i=origine; i!=NULL && resultat==NULL; i=i->ai_next)
{
|
351d9caa
Speedclocker
Ajout de serveur/...
|
31
32
33
|
if(i->ai_family==AF_INET)
{
resultat=i;
|
8450f712
Antoine Moreau
fin
|
34
35
|
//printf("Test : %d\n", origine->ai_addrlen);
}
|
351d9caa
Speedclocker
Ajout de serveur/...
|
36
37
|
}
|
8450f712
Antoine Moreau
fin
|
38
39
40
|
/* struct sockaddr_in* test=(struct sockaddr_in*)(resultat->ai_addr); */
/* printf("Addr : %x\n", test->sin_addr.s_addr); */
|
351d9caa
Speedclocker
Ajout de serveur/...
|
41
42
43
44
|
if((sock_fd=socket(resultat->ai_family, resultat->ai_socktype, resultat->ai_protocol))<0) { fprintf(stderr, "Erreur socket\n"); return(-1); }
int val=1;
|
08f8ef8d
skhinach
modifs
|
45
|
if(setsockopt(sock_fd, SOL_SOCKET, SO_REUSEADDR, &val, sizeof(val))<0) { fprintf(stderr, "Erreur setsockopt\n"); return(-1); }
|
351d9caa
Speedclocker
Ajout de serveur/...
|
46
|
|
08f8ef8d
skhinach
modifs
|
47
|
if(setsockopt(sock_fd, SOL_SOCKET, SO_BROADCAST, &val, sizeof(val))<0) { fprintf(stderr, "Erreur setsockopt\n"); return(-1); }
|
351d9caa
Speedclocker
Ajout de serveur/...
|
48
49
50
51
52
53
54
55
56
57
58
|
if(bind(sock_fd, resultat->ai_addr, resultat->ai_addrlen)) { fprintf(stderr, "Erreur bind\n"); return(-1); }
if(listen(sock_fd, 20) < 0) { fprintf(stderr, "Error listen server socket\n"); return (-1); }
freeaddrinfo(origine);
return sock_fd;
}
|
685f1984
Speedclocker
Ajout threads
|
59
|
|
685f1984
Speedclocker
Ajout threads
|
60
61
|
|
351d9caa
Speedclocker
Ajout de serveur/...
|
62
63
64
|
int boucleServeur(int socket, void(* fctConnex)(int))
{
int sock_dial;
|
3b480342
Speedclocker
Modification serveur
|
65
|
|
a69a94a7
skhinach
Ajout de gestion ...
|
66
|
//On utilisera la structure Arg_Thread (définie dans libthrd.h) qui comprend la socket de dialogue et le tableau pointeurs vers une structure donnant les infos des interfaces.
|
8450f712
Antoine Moreau
fin
|
67
|
//En effet, cette structure d'informations d'interface permet d'être utilisée comme une base de données, comprenant l'adresse de l'interface, son statut et sa commande
|
a69a94a7
skhinach
Ajout de gestion ...
|
68
|
//Les threads partageant la mémoire, ces infos seront partagées.
|
5940bf6e
skhinach
Quelques modifs
|
69
70
71
|
//Afin de gérer les requêtes, il est nécessaire d'instaurer un mutex.
//En effet, la ressource interfaces ne doit être accessible que par un seul thread à la fois
|
a69a94a7
skhinach
Ajout de gestion ...
|
72
73
74
75
76
77
78
|
Arg_Thread arg_sock_interf;
//On initialise les interfaces
for(int i=0; i<20; i++)
arg_sock_interf.interfaces[i]=NULL;
|
5940bf6e
skhinach
Quelques modifs
|
79
80
81
|
//On initialiser le mutex
pthread_mutex_init(&(arg_sock_interf.requete_mutex), NULL);
|
b159f2fa
Speedclocker
Amélioration serveur
|
82
83
|
printf("------- Début boucle serveur TCP -------\n\n");
|
351d9caa
Speedclocker
Ajout de serveur/...
|
84
85
|
while(1)
{
|
b159f2fa
Speedclocker
Amélioration serveur
|
86
|
printf("-- boucle --\n");
|
351d9caa
Speedclocker
Ajout de serveur/...
|
87
|
if((sock_dial=accept(socket, NULL, NULL)) < 0){ fprintf(stderr, "Error accept dialogue\n"); return -1; }
|
b159f2fa
Speedclocker
Amélioration serveur
|
88
|
printf("Dialogue ACCEPTED\n");
|
685f1984
Speedclocker
Ajout threads
|
89
|
|
a69a94a7
skhinach
Ajout de gestion ...
|
90
91
92
|
arg_sock_interf.socket=sock_dial;
lanceThread((void*)fctConnex, (void*)&arg_sock_interf, sizeof(arg_sock_interf));
|
351d9caa
Speedclocker
Ajout de serveur/...
|
93
|
}
|
5940bf6e
skhinach
Quelques modifs
|
94
|
pthread_mutex_destroy(&(arg_sock_interf.requete_mutex));
|
351d9caa
Speedclocker
Ajout de serveur/...
|
95
|
}
|