diff --git a/webserver/client.c b/webserver/client.c
index 9af3250a70b17a8076c0cae02bf97e38b76780c9..1712a3287f709346c52ab8b8f71c0b6ef66d99e6 100644
--- a/webserver/client.c
+++ b/webserver/client.c
@@ -7,6 +7,17 @@
 #include <stdlib.h>
 #include "client.h"
 
+int testCorrect(char* str){
+	char *correctStr = "GET / HTTP/1.1";
+	char *incorrectStr = "HTTP/1.1 400 Bad Request\r\nConnection: close\r\nContent-Length: 17\r\n\r\n400 Bad request";
+	if(strstr(str,correctStr) == NULL){
+		str=incorrectStr;
+		//printf("---\n%s\n---",str);
+	}
+	printf("---\n%s\n---",str);
+	return 0;
+}
+
 int traitementClient(int socket_client){
 			/* On peut maintenant dialoguer avec le client */
 			//const char *message_bienvenue = "Bonjour, bienvenue sur mon serveur\nExcogitatum est super his, ut homines quidam ignoti, vilitate ipsa parum cavendi ad colligendos rumores per Antiochiae latera cuncta destinarentur relaturi quae audirent. hi peragranter et dissimulanter honoratorum circulis adsistendo pervadendoque divites domus egentium habitu quicquid noscere poterant vel audire latenter intromissi per posticas in regiam nuntiabant, id observantes conspiratione concordi, ut fingerent quaedam et cognita duplicarent in peius, laudes vero supprimerent Caesaris, quas invitis conpluribus formido malorum inpendentium exprimebat.Sed fruatur sane hoc solacio atque hanc insignem ignominiam, quoniam uni praeter se inusta sit, putet esse leviorem, dum modo, cuius exemplo se consolatur, eius exitum expectet, praesertim cum in Albucio nec Pisonis libidines nec audacia Gabini fuerit ac tamen hac una plaga conciderit, ignominia senatus.Post emensos insuperabilis expeditionis eventus languentibus partium animis, quas periculorum varietas fregerat et laborum, nondum tubarum cessante clangore vel milite locato per stationes hibernas, fortunae saevientis procellae tempestates alias rebus infudere communibus per multa illa et dira facinora Caesaris Galli, qui ex squalore imo miseriarum in aetatis adultae primitiis ad principale culmen insperato saltu provectus ultra terminos potestatis delatae procurrens asperitate nimia cuncta foedabat. propinquitate enim regiae stirpis gentilitateque etiam tum Constantini nominis efferebatur in fastus, si plus valuisset, ausurus hostilia in auctorem suae felicitatis, ut videbatur.";
@@ -23,11 +34,12 @@ int traitementClient(int socket_client){
 				exit(1);
 			}
 			//printf("test avant while\n");
-			while(!feof(fd) && fgets(str,8000,fd) != NULL){
-													/* writing content to stdout */
+			while(!feof(fd) && fgets(str,8000,fd) != NULL){									/* writing content to stdout */
+				testCorrect(str);
 				fprintf(fd,"<Notre Serveur> %s",str);
 				fflush(fd);
 			}
+			//fflush(fd);
 			fclose(fd);
     return 0;
 }
diff --git a/webserver/client.o b/webserver/client.o
index de41bc6b84ba323962b63c2b255b4ce2dcc06c58..ac200b8981ca3855015d6c7822593514dd56ea2c 100644
Binary files a/webserver/client.o and b/webserver/client.o differ
diff --git a/webserver/pawnee b/webserver/pawnee
index 0896d00451403591d6d571ca45211cfcaf657d69..14024973144badce5a1505c7741e58351be88716 100755
Binary files a/webserver/pawnee and b/webserver/pawnee differ
diff --git a/webserver/socket.c b/webserver/socket.c
index 14c431fdea63ae9822ea925b4a66855ca103f45f..b91b084db34f0c7d09cdfc3c75cae6735b6ba7ff 100644
--- a/webserver/socket.c
+++ b/webserver/socket.c
@@ -62,9 +62,9 @@ int creer_serveur(int port){
             
 		}else{ // à déplacer ailleurs pour une meilleure lisibilité
 			 //traitement final
-            traitementClient(socket_client);
+        		traitementClient(socket_client);
+			
 			printf("fin du client\n");
-            //close(socket_client);
 			exit(0);
 		}
 	}
diff --git a/webserver/socket.c.save.3 b/webserver/socket.c.save.3
new file mode 100644
index 0000000000000000000000000000000000000000..321ca83426801d88acc6ba2db973eb1a5bccc163
--- /dev/null
+++ b/webserver/socket.c.save.3
@@ -0,0 +1,71 @@
+#include <string.h>
+#include <unistd.h>
+#include <stdio.h>
+#include "socket.h"
+#include <netinet/in.h>
+#include <sys/wait.h>
+#include <stdlib.h>
+#include "client.h"
+
+
+int creer_serveur(int port){
+//socket
+	int socket_serveur;
+	socket_serveur = socket(AF_INET, SOCK_STREAM, 0);
+	if (socket_serveur == -1) {
+		/* traitement de l'erreur */
+		perror("socket_serveur");
+		exit(1);
+	}
+
+	int optval = 1;
+	if (setsockopt(socket_serveur, SOL_SOCKET, SO_REUSEADDR, &optval, sizeof(int)) == -1) {
+		perror("Can not set SO_REUSEADDR option");
+		exit(1);
+	}
+
+	/*Utilisation de la socket serveur */
+//bind
+	struct sockaddr_in saddr;
+	saddr.sin_family = AF_INET; /* Socket ipv4 */
+	saddr.sin_port = htons(port); /* Port d'écoute */
+	saddr.sin_addr.s_addr = INADDR_ANY; /* écoute sur toutes les interfaces */
+	if (bind(socket_serveur, (struct sockaddr *)&saddr, sizeof(saddr)) == -1){
+		perror("bind socker_serveur");
+		/* traitement de l'erreur */
+		exit(1);
+	}
+
+//listen
+	if (listen(socket_serveur, 10) == -1) {
+		perror("listen socket_serveur");
+		/* traitement d'erreur */
+		exit(1);
+	}
+//decouper ici ---
+	int socket_client;
+	while(1){
+		socket_client = accept(socket_serveur, NULL, NULL);
+
+		if (socket_client == -1) {
+			perror("accept");
+			/* traitement d'erreur */
+			exit(1);
+		}
+
+		int pid = fork();
+		if(pid == -1){
+			perror("fork fail");
+			exit(1);
+		}else if(pid > 0) {
+			//close(socket_client);  fait une erreur si on le met
+            
+		}else{ // à déplacer ailleurs pour une meilleure lisibilité
+			 //traitement final
+        		traitementClient(socket_client);
+			printf("fin du client\n");
+			exit(0);
+		}
+	}
+	return 0;
+}