Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
76a81fe0f1
@ -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;
|
||||||
|
@ -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;
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user