mirror of
https://github.com/yoboujon/tsock.git
synced 2025-06-08 14:00:50 +02:00
commit
0bba512a36
7 changed files with 81 additions and 61 deletions
|
@ -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
|
|
@ -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
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
64
src/puit.c
64
src/puit.c
|
@ -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;
|
|
||||||
}
|
|
30
src/source.c
30
src/source.c
|
@ -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;
|
||||||
}
|
}
|
29
src/tsock.c
29
src/tsock.c
|
@ -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;
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue