Merge remote-tracking branch 'origin/master'

This commit is contained in:
MKDrwal 2019-12-01 19:39:31 +01:00
commit 76a81fe0f1
2 changed files with 40 additions and 55 deletions

View File

@ -9,23 +9,15 @@
#include <netdb.h> #include <netdb.h>
#include <sys/time.h> #include <sys/time.h>
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
char odbior[10];
struct sockaddr_in endpoint;
int sdsocket, addrlen, sdconnection;
const int port = 7332; const int port = 7332;
const char ip[512] = "192.168.1.30"; const char ip[512] = "192.168.1.30";
char buff[512]; struct sockaddr_in endpoint;
char eee[1];
struct dirent **namelist; struct dirent **namelist;
int n; char buff[512];
char wiadomosc[512];
char mess[512];
char name_file[512]; char name_file[512];
int sdsocket, addrlen, sdconnection, n;
endpoint.sin_family = AF_INET; endpoint.sin_family = AF_INET;
endpoint.sin_port = htons(port); endpoint.sin_port = htons(port);
@ -35,8 +27,8 @@ int main(int argc, char **argv)
while (1) while (1)
{ {
start: start:
printf("Wpisz zapytanie do serwera\n"); printf("Enter the server query\n");
bzero(buff, 512);
scanf("%s", buff); scanf("%s", buff);
if (strncmp("CLIENTOFF", buff, 9) == 0) if (strncmp("CLIENTOFF", buff, 9) == 0)
@ -46,34 +38,35 @@ int main(int argc, char **argv)
} }
else if (strncmp("HELP", buff, 4) == 0) else if (strncmp("HELP", buff, 4) == 0)
{ {
printf("COMMAND LIST:\n CLIENTOFF\n EXIT\n GET_ALL_FILES\n"); printf("COMMAND LIST:\n CLIENTOFF\n EXIT\n GET_ALL_FILES\n FTP_namefile\n");
goto start; goto start;
} }
if ((sdsocket = socket(AF_INET, SOCK_STREAM, 0)) < 0) if ((sdsocket = socket(AF_INET, SOCK_STREAM, 0)) < 0)
{ {
printf("socket() nie powiodl sie (failed)\n"); printf("socket() failed\n");
return 1; return 1;
} }
if (connect(sdsocket, (struct sockaddr *)&endpoint, addrlen) < 0) if (connect(sdsocket, (struct sockaddr *)&endpoint, addrlen) < 0)
{ {
printf("connect() nie powiodl sie (failed)\n"); printf("connect() failed\n");
return 0; return 0;
} }
else else
printf("CONNECTED\n"); printf("CONNECTED\n");
send(sdsocket, buff, 512, 0); send(sdsocket, buff, 512, 0);
close(sdsocket); close(sdsocket);
if ((sdsocket = socket(AF_INET, SOCK_STREAM, 0)) < 0) if ((sdsocket = socket(AF_INET, SOCK_STREAM, 0)) < 0)
{ {
printf("socket() nie powiodl sie (failed)\n"); printf("socket() failed\n");
return 1; return 1;
} }
if (connect(sdsocket, (struct sockaddr *)&endpoint, addrlen) < 0) if (connect(sdsocket, (struct sockaddr *)&endpoint, addrlen) < 0)
{ {
printf("connect() nie powiodl sie (failed)\n"); printf("connect() failed\n");
return 0; return 0;
} }
@ -81,18 +74,16 @@ int main(int argc, char **argv)
{ {
ssize_t total = 0; ssize_t total = 0;
strncpy(name_file, buff + 4, 509); strncpy(name_file, buff + 4, 509);
printf("dlugość nazwy:%ld\n", strlen(name_file)); printf("Name of file :%s\n", name_file);
printf("Plik do wyslania :%s\n", name_file);
FILE *file = fopen(name_file, "wb"); FILE *file = fopen(name_file, "wb");
if (file == NULL) if (file == NULL)
{ {
printf("Nie udalo sie otowrzyc pliku"); printf("fopen() failed");
} }
char addr[INET_ADDRSTRLEN]; char addr[INET_ADDRSTRLEN];
printf("Pobieranie pliku: %s od %s\n", name_file, inet_ntop(AF_INET, &endpoint.sin_addr.s_addr, addr, INET_ADDRSTRLEN)); printf("Downloading file: %s od %s\n", name_file, inet_ntop(AF_INET, &endpoint.sin_addr.s_addr, addr, INET_ADDRSTRLEN));
ssize_t n; ssize_t n;
char buff[4096] = {0}; char buff[4096] = {0};
@ -101,27 +92,26 @@ int main(int argc, char **argv)
total += n; total += n;
if (n == -1) if (n == -1)
{ {
printf("recv Error"); printf("recv() failed");
} }
if (fwrite(buff, sizeof(char), n, file) != n) if (fwrite(buff, sizeof(char), n, file) != n)
{ {
printf("fwrite Error"); printf("fwrite() failed");
} }
memset(buff, 0, 4096); memset(buff, 0, 4096);
} }
printf("Przesylanie udane liczba bajtow = %ld\n", total); printf("Downloading succes, numer of bytes = %ld\n", total);
fclose(file); fclose(file);
goto start; goto start;
} }
bzero(odbior, 512); bzero(buff, 512);
recv(sdsocket, odbior, 512, 0); recv(sdsocket, buff, 512, 0);
printf("%s\n", odbior); printf("%s\n", buff);
} }
return 0; return 0;

View File

@ -9,17 +9,17 @@
#include <netdb.h> #include <netdb.h>
#include <dirent.h> #include <dirent.h>
ssize_t count = 0;
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
const int port = 7332; const int port = 7332;
struct sockaddr_in myaddr, endpoint; struct sockaddr_in myaddr, endpoint;
int sdsocket, sdconnection, addrlen, sdconnection2, n, rec;
char odbior[512];
struct dirent **namelist; struct dirent **namelist;
char buff[512];
char name_file[512]; char name_file[512];
char names_files[512]; char names_files[512];
int sdsocket, sdconnection, addrlen, sdconnection2, n, x;
ssize_t count = 0;
sdsocket = socket(AF_INET, SOCK_STREAM, 0); sdsocket = socket(AF_INET, SOCK_STREAM, 0);
addrlen = sizeof(struct sockaddr_in); addrlen = sizeof(struct sockaddr_in);
@ -30,13 +30,13 @@ int main(int argc, char **argv)
if (bind(sdsocket, (struct sockaddr *)&myaddr, addrlen) < 0) if (bind(sdsocket, (struct sockaddr *)&myaddr, addrlen) < 0)
{ {
printf("bind() nie powiodl sie (failed)\n"); printf("bind() failed\n");
return 1; return 1;
} }
if (listen(sdsocket, 10) < 0) if (listen(sdsocket, 10) < 0)
{ {
printf("listen() nie powiodl sie (failed)\n"); printf("listen() failed\n");
return 1; return 1;
} }
@ -50,12 +50,12 @@ int main(int argc, char **argv)
{ {
printf("CONNECT FROM : %s\n ", inet_ntoa(endpoint.sin_addr)); printf("CONNECT FROM : %s\n ", inet_ntoa(endpoint.sin_addr));
bzero(odbior, 512); bzero(buff, 512);
rec = recv(sdconnection, odbior, 512, 0); recv(sdconnection, buff, 512, 0);
close(sdconnection); close(sdconnection);
if (strncmp("GET_ALL_FILES", odbior, 13) == 0) if (strncmp("GET_ALL_FILES", buff, 13) == 0)
{ {
printf("Sending list of names files\n"); printf("Sending list of names files\n");
@ -72,7 +72,6 @@ int main(int argc, char **argv)
while (n--) while (n--)
{ {
sprintf(name_file, "%s\n", namelist[n]->d_name); sprintf(name_file, "%s\n", namelist[n]->d_name);
strcat(names_files, name_file); strcat(names_files, name_file);
free(namelist[n]); free(namelist[n]);
@ -91,27 +90,24 @@ int main(int argc, char **argv)
break; break;
} }
} }
else if (strncmp("EXIT", odbior, 4) == 0) else if (strncmp("EXIT", buff, 4) == 0)
{ {
printf("Server shut down..\n"); printf("Server shut down..\n");
close(sdsocket); close(sdsocket);
return 0; return 0;
} }
else if (strncmp("FTP", odbior, 3) == 0) else if (strncmp("FTP", buff, 3) == 0)
{ {
bzero(name_file, 512); bzero(name_file, 512);
strncpy(name_file, buff + 4, 509);
strncpy(name_file, odbior + 4, 509); printf("File to send :%s\n", name_file);
printf("dlugość nazwy:%ld\n", strlen(name_file));
printf("Plik do wyslania :%s\n", name_file);
FILE *file = fopen(name_file, "rb"); FILE *file = fopen(name_file, "rb");
if (file == NULL) if (file == NULL)
{ {
printf("Open file failed"); printf("fopen() failed");
} }
while ((sdconnection2 = while ((sdconnection2 =
@ -120,7 +116,6 @@ int main(int argc, char **argv)
&addrlen)) >= 0) &addrlen)) >= 0)
{ {
int x;
char package[4096] = {0}; char package[4096] = {0};
while ((x = fread(package, sizeof(char), 4096, file)) > 0) while ((x = fread(package, sizeof(char), 4096, file)) > 0)
{ {
@ -128,28 +123,28 @@ int main(int argc, char **argv)
if (send(sdconnection2, package, x, 0) == -1) if (send(sdconnection2, package, x, 0) == -1)
{ {
printf("Send failed"); printf("send() failed");
} }
memset(package, 0, 4096); memset(package, 0, 4096);
} }
printf("Send Success, NumBytes = %ld\n", count); printf("Send success, number of bytes: %ld\n", count);
fclose(file);
fclose(file);
close(sdconnection2); close(sdconnection2);
break; break;
} }
} }
else else
{ {
printf("Wrong query\n %s nie istnieje\n", odbior); printf("Wrong query: %s\n", buff);
while ((sdconnection2 = while ((sdconnection2 =
accept(sdsocket, accept(sdsocket,
(struct sockaddr *)&endpoint, (struct sockaddr *)&endpoint,
&addrlen)) >= 0) &addrlen)) >= 0)
{ {
send(sdconnection2, "wrong query", 512, 0); send(sdconnection2, "Wrong query", 512, 0);
close(sdconnection2); close(sdconnection2);
break; break;
@ -159,4 +154,4 @@ int main(int argc, char **argv)
} }
close(sdsocket); close(sdsocket);
return 0; return 0;
} }