diff options
author | Santo Cariotti <santo@dcariotti.me> | 2021-11-01 22:40:58 +0100 |
---|---|---|
committer | Santo Cariotti <santo@dcariotti.me> | 2021-11-01 22:40:58 +0100 |
commit | 5496448b6a2a06e774ad93918b18415972e33fdc (patch) | |
tree | 770ce3d413bb3000c79e6b14360a49af380bea25 /Year_3/TSDWL/socket_tcp/server.c | |
parent | a1ebb23463f0859013fd03bcf3e0c2234ebb3322 (diff) |
tsdwl: add socket tcp client/server
Diffstat (limited to 'Year_3/TSDWL/socket_tcp/server.c')
-rw-r--r-- | Year_3/TSDWL/socket_tcp/server.c | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/Year_3/TSDWL/socket_tcp/server.c b/Year_3/TSDWL/socket_tcp/server.c new file mode 100644 index 0000000..7e9da88 --- /dev/null +++ b/Year_3/TSDWL/socket_tcp/server.c @@ -0,0 +1,77 @@ +#include <netdb.h> +#include <netinet/in.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <sys/socket.h> +#include <sys/types.h> +#include <unistd.h> + +#define PORT 3030 +#define CONNECTIONS_NUM 1 + +int +main(int argc, char* argv[]) +{ + int sockfd, clientfd; + struct sockaddr_in address; + socklen_t addrlen; + int nbytes, ntotbytes; + char buffer[1024]; + + if ((sockfd = socket(PF_INET, SOCK_STREAM, 0)) == -1) { + perror("Error creating a new socket"); + exit(1); + } + + address.sin_family = AF_INET; + address.sin_port = htons(atoi(argv[1])); + address.sin_addr.s_addr = INADDR_ANY; + + addrlen = sizeof(address); + + if (bind(sockfd, (struct sockaddr*)&address, addrlen) == -1) { + perror("Error binding the port"); + exit(1); + } + + if (listen(sockfd, CONNECTIONS_NUM) == -1) { + perror("Can't listen that port"); + exit(1); + } + + while (1) { + if ((clientfd = accept(sockfd, (struct sockaddr*)&address, &addrlen)) == -1) { + perror("Can't accept request from client"); + break; + } + + ntotbytes = 0; + while ((nbytes = recv(clientfd, buffer, 1024, 0)) != 0) { + if (nbytes == -1) { + perror("Error reading the client"); + break; + } + + buffer[nbytes] = '\0'; + if (strncmp(buffer, "quit", 4) == 0) { + break; + } + + printf("%s", buffer); + ntotbytes += nbytes; + } + + sprintf(buffer, "Total bytes read: %d\n", ntotbytes); + + if ((nbytes = send(clientfd, buffer, strlen(buffer), 0)) != strlen(buffer)) { + perror("Error sending back a message"); + } + + close(clientfd); + } + + close(sockfd); + + return 0; +} |