Merge pull request #6 from yoboujon/yohan

Yohan
This commit is contained in:
sparis1206 2023-01-13 15:19:32 +01:00 committed by GitHub
commit 0bba512a36
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 81 additions and 61 deletions

View file

@ -3,6 +3,5 @@
#include "tsock.h" #include "tsock.h"
int launchPuit(int nombreMessage,int tailleMessage,int isTCP); int launchPuit(int nombreMessage,int tailleMessage,int isTCP);
int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct); int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP);
int exitMax(int var,int tailleMax);
#endif #endif

View file

@ -3,6 +3,6 @@
#include "tsock.h" #include "tsock.h"
int launchSource(int nombreMessage,int tailleMessage,int isTCP); int launchSource(int nombreMessage,int tailleMessage,int isTCP);
int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct); int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP);
#endif #endif

View file

@ -1,21 +1,23 @@
#ifndef HEADER_TSOCK #ifndef HEADER_TSOCK
#define HEADER_TSOCK #define HEADER_TSOCK
#include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h>
#include <unistd.h> #include <unistd.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/socket.h> #include <sys/socket.h>
#include <sys/un.h> #include <sys/un.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <netdb.h> #include <netdb.h>
#include <stdio.h>
#include <errno.h> #include <errno.h>
#include <string.h>
void setNbMessage(int * nb, int source); void setNbMessage(int * nb, int source);
void printInfo(int nb, int source, int portNumber, char ipAddress[]); void printInfo(int nb, int source, int portNumber, char ipAddress[]);
void initStructSocket(struct sockaddr_in *socketServerTemp, int source); void initStructSocket(struct sockaddr_in *socketServerTemp, int source);
void getNonOtpArgs(char ** argv, int argc, int portNumber, char * ipAddress[]); void getNonOtpArgs(char ** argv, int argc, int portNumber, char * ipAddress[]);
void formatText(char * actualMessage, int num, int tailleMessage, char messageChar);
int exitMax(int var,int tailleMax);
#define PORT_NUM 9000 #define PORT_NUM 9000

View file

@ -8,7 +8,7 @@ int main (int argc, char **argv)
char *ipAddress; char *ipAddress;
extern char *optarg; extern char *optarg;
extern int optind; extern int optind;
int source = -1, nb_message = -1, c, tcp=1, port=9000, tailleMessage; /* Nb de messages à envoyer ou à recevoir, par défaut : 10 en émission, infini en réception */ int source = -1, nb_message = -1, c, tcp=1, port=9000, tailleMessage=-1; /* Nb de messages à envoyer ou à recevoir, par défaut : 10 en émission, infini en réception */
while ((c = getopt(argc, argv, "pn:sul:")) != -1) { while ((c = getopt(argc, argv, "pn:sul:")) != -1) {
switch (c) { switch (c) {
case 'p': case 'p':
@ -45,6 +45,10 @@ int main (int argc, char **argv)
printf(usageChar); printf(usageChar);
exit(1); exit(1);
} }
if(tailleMessage == -1)
{
tailleMessage = 30;
}
getNonOtpArgs(argv, argc, port, &ipAddress); getNonOtpArgs(argv, argc, port, &ipAddress);
setNbMessage(&nb_message,source); setNbMessage(&nb_message,source);

View file

@ -4,14 +4,7 @@ int launchPuit(int nombreMessage,int tailleMessage,int isTCP)
{ {
int sock,socketType; int sock,socketType;
struct sockaddr_in socketPuit; struct sockaddr_in socketPuit;
if(isTCP) socketType = (isTCP) ? SOCK_STREAM : SOCK_DGRAM;
{
socketType=SOCK_STREAM;
}
else
{
socketType=SOCK_DGRAM;
}
if((sock=socket(AF_INET,socketType,0)) == -1) if((sock=socket(AF_INET,socketType,0)) == -1)
{ {
@ -24,55 +17,52 @@ int launchPuit(int nombreMessage,int tailleMessage,int isTCP)
perror("[tsock] : fonction bind() : echec du lien avec socket serveur.\n"); perror("[tsock] : fonction bind() : echec du lien avec socket serveur.\n");
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
if(isTCP) receiveMultipleData(nombreMessage,tailleMessage,sock,socketPuit,isTCP);
{
unsigned int longueurRecu = sizeof(socketPuit);
char messageRecu[30];
listen(sock,10);
int acceptValue = accept(sock,(struct sockaddr *)&socketPuit,&longueurRecu);
printf("AcceptValue = %d\n",acceptValue);
int tailleMessageRecu = read(acceptValue,messageRecu,sizeof(messageRecu));
messageRecu[tailleMessageRecu]='\0';
printf("Message TCP [%d] : %s\n",tailleMessageRecu,messageRecu);
}
else
{
receiveMultipleData(nombreMessage,tailleMessage,sock,socketPuit);
}
close(sock); close(sock);
return 0; return 0;
} }
int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct) int receiveMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP)
{ {
char messageRecu[tailleMessage+1]; char messageRecu[tailleMessage+1];
int n, longueurRecu = sizeof(socketStruct); int n=1, longueurRecu = sizeof(socketStruct);
if(isTCP)
{
listen(sock,5);
sock = accept(sock,(struct sockaddr *)&socketStruct,(socklen_t * restrict)&longueurRecu);
}
if(nombreMessages < 0) if(nombreMessages < 0)
{ {
int i=1; int i=1;
while(1) while(n>0)
{ {
n = recvfrom(sock, (char *)messageRecu, tailleMessage, 0, (struct sockaddr*) &socketStruct,(socklen_t *__restrict__)&longueurRecu); if(isTCP)
{
n = read(sock,messageRecu,tailleMessage);
}
else
{
n = recvfrom(sock, (char *)messageRecu, tailleMessage, 0, (struct sockaddr*) &socketStruct,(socklen_t *__restrict__)&longueurRecu);
}
messageRecu[n] = '\0'; messageRecu[n] = '\0';
printf("Puit\tReception n°%d (%d) :\t[%s]\n",i,tailleMessage,messageRecu); printf("Puit\tReception n°%d (%d) :\t[%s]\n",i,n,messageRecu);
i++; i++;
} }
} }
else{ else{
for(int i=0;i<nombreMessages;i++) for(int i=0;i<nombreMessages;i++)
{ {
n = recvfrom(sock, (char *)messageRecu, tailleMessage, 0, (struct sockaddr*) &socketStruct,(socklen_t *__restrict__)&longueurRecu); if(isTCP)
{
n = read(sock,messageRecu,tailleMessage);
}
else
{
n = recvfrom(sock, (char *)messageRecu, tailleMessage, 0, (struct sockaddr*) &socketStruct,(socklen_t *__restrict__)&longueurRecu);
}
messageRecu[n] = '\0'; messageRecu[n] = '\0';
printf("Puit\tReception n°%d (%d) :\t[%s]\n",i+1,tailleMessage,messageRecu); printf("Puit\tReception n°%d (%d) :\t[%s]\n",i+1,tailleMessage,messageRecu);
} }
} }
return 0; return 0;
} }
int exitMax(int var,int tailleMax){
if(var>1500){
printf("-l doit être <1500 \n");
exit(EXIT_FAILURE);
}
return 0;
}

View file

@ -4,14 +4,7 @@ int launchSource(int nombreMessage,int tailleMessage,int isTCP)
{ {
int sock,socketType; int sock,socketType;
struct sockaddr_in socketSource; struct sockaddr_in socketSource;
if(isTCP) socketType = (isTCP) ? SOCK_STREAM : SOCK_DGRAM;
{
socketType=SOCK_STREAM;
}
else
{
socketType=SOCK_DGRAM;
}
if((sock=socket(AF_INET,socketType,0)) == -1) if((sock=socket(AF_INET,socketType,0)) == -1)
{ {
@ -22,30 +15,35 @@ int launchSource(int nombreMessage,int tailleMessage,int isTCP)
if(isTCP) if(isTCP)
{ {
connect(sock,(struct sockaddr *)&socketSource,(socklen_t)sizeof(socketSource)); connect(sock,(struct sockaddr *)&socketSource,(socklen_t)sizeof(socketSource));
printf("Connect successful\n"); sendMultipleData(nombreMessage,tailleMessage,sock,socketSource,isTCP);
int isWritten = write(sock,"aaaaaa",sizeof("aaaaaa"));
printf("on écrit : %d\n",isWritten);
} }
else else
{ {
sendMultipleData(nombreMessage,tailleMessage,sock,socketSource); sendMultipleData(nombreMessage,tailleMessage,sock,socketSource,isTCP);
} }
close(sock); close(sock);
return 0; return 0;
} }
int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct) int sendMultipleData(int nombreMessages, int tailleMessage, int sock, struct sockaddr_in socketStruct, int isTCP)
{ {
int longueurEmis; int longueurEmis;
char messageChar='a'; char messageChar='a';
char sendingMessage[tailleMessage]; char sendingMessage[tailleMessage];
for(int i=0;i<nombreMessages;i++) for(int i=0;i<nombreMessages;i++)
{ {
memset(sendingMessage, messageChar, tailleMessage*sizeof(char)+1); formatText(sendingMessage,i,tailleMessage,messageChar);
longueurEmis=sendto(sock, sendingMessage, tailleMessage, 0, (struct sockaddr*)&socketStruct, sizeof(socketStruct)); if(isTCP)
{
longueurEmis = write(sock,sendingMessage,sizeof(sendingMessage));
}
else
{
longueurEmis = sendto(sock, sendingMessage, tailleMessage, 0, (struct sockaddr*)&socketStruct, sizeof(socketStruct));
}
sendingMessage[tailleMessage]='\0'; sendingMessage[tailleMessage]='\0';
printf("Source\tEnvoi n°%d (%d) :\t[%s]\n",i+1,longueurEmis,sendingMessage); printf("Source\tEnvoi n°%d (%d) :\t[%s]\n",i+1,longueurEmis,sendingMessage);
messageChar++; messageChar>='z'?messageChar='a':messageChar++;
} }
return 0; return 0;
} }

View file

@ -40,7 +40,6 @@ void initStructSocket(struct sockaddr_in *socketTempStruct, int source)
else else
{ {
socketTempStruct->sin_addr.s_addr=INADDR_ANY; socketTempStruct->sin_addr.s_addr=INADDR_ANY;
} }
} }
@ -51,3 +50,31 @@ void getNonOtpArgs(char ** argv, int argc, int portNumber, char ** ipAddress)
*ipAddress = (char *)malloc(sizeof(argv[argc-1])); *ipAddress = (char *)malloc(sizeof(argv[argc-1]));
strcpy(*ipAddress,argv[argc-1]); strcpy(*ipAddress,argv[argc-1]);
} }
void formatText(char * actualMessage, int num, int tailleMessage, char messageChar)
{
char numBuffer[15];
sprintf(numBuffer, "%d", (num+1)%10000);
int numberLength=0;
while(numBuffer[numberLength] != '\0')
{
numberLength++;
}
for(int i=0;i<4-numberLength;i++)
{
actualMessage[i]=0x20;
}
for(int i=4-numberLength,j=0;i<4;i++,j++)
{
actualMessage[i]=numBuffer[j];
}
memset(actualMessage+4, messageChar, tailleMessage);
}
int exitMax(int var,int tailleMax){
if(var>1500){
printf("-l doit être <1500 \n");
exit(EXIT_FAILURE);
}
return 0;
}