Fixed endless loading webpage

This commit is contained in:
TriantaTV 2023-10-03 22:03:21 -05:00
parent abab69344a
commit b3c970beb4
2 changed files with 28 additions and 12 deletions

View File

@ -1,7 +1,8 @@
#include "network.hpp" #include "network.hpp"
#include <arpa/inet.h> #include <arpa/inet.h>
#include <fcntl.h>
#include <stdlib.h> // Needed for exit() #include <stdlib.h> // Needed for exit()
#include <string.h> // Needed for strcpy() and strlen() #include <cstring>
#include <iostream> #include <iostream>
void TestSockets(int sender_s, int receiver_s) { void TestSockets(int sender_s, int receiver_s) {
@ -45,19 +46,24 @@ void TestSockets(int sender_s, int receiver_s) {
void PipeSockets(int sender_s, int receiver_s) { void PipeSockets(int sender_s, int receiver_s) {
char in_buf[BUF_SIZE]; // Input buffer for GET resquest char in_buf[BUF_SIZE]; // Input buffer for GET resquest
ssize_t buf_len; // Buffer length for file reads ssize_t buf_len; // Buffer length for file reads
//
// Pass GET along from browser to server // Pass GET along from browser to server
std::cout << "Attempting to send data to receiver" << std::endl; std::cout << "Attempting to send data to receiver" << std::endl;
do { do {
// Receive
buf_len = recv(sender_s, in_buf, BUF_SIZE, 0); buf_len = recv(sender_s, in_buf, BUF_SIZE, 0);
std::cout << "LOG (info) - pipe packet recv size: " << buf_len << std::endl; std::cout << "LOG (info) - pipe packet recv size: " << buf_len << '\n';
if (buf_len == -1) { if (buf_len == -1) {
std::cout << "ERROR (info) - recv" << std::endl; std::cout << "ERROR (info) - recv" << std::endl;
close(sender_s);
close(receiver_s);
return; return;
} }
if (buf_len == 0) { break; } if (buf_len == 0) { continue; }
// Send
buf_len = send(receiver_s, in_buf, buf_len, 0); buf_len = send(receiver_s, in_buf, buf_len, 0);
std::cout << "LOG (info) - pipe packet send size: " << buf_len << std::endl; std::cout << "LOG (info) - pipe packet send size: " << buf_len << '\n';
} while (buf_len == BUF_SIZE); } while (buf_len == BUF_SIZE);
std::cout << "Sent data to receiver" << std::endl; std::cout << "Sent data to receiver" << std::endl;
@ -70,19 +76,19 @@ void ProxySockets(int sender_s, int receiver_s) {
// Pass response along from server to browser // Pass response along from server to browser
std::cout << "Attempting to send to browser" << std::endl; std::cout << "Attempting to send to browser" << std::endl;
do { do {
// Receive
buf_len = recv(sender_s, out_buf, BUF_SIZE, 0); buf_len = recv(sender_s, out_buf, BUF_SIZE, 0);
std::cout << "LOG (info) - proxy packet recv size: " << buf_len << std::endl; std::cout << "LOG (info) - proxy packet recv size: " << buf_len << '\n';
if (buf_len == -1) { if (buf_len == -1) {
std::cout << "ERROR (info) - recv -1" << std::endl; std::cout << "ERROR (info) - recv -1" << std::endl;
return; return;
} }
if (buf_len == 0) {
std::cout << "ERROR (info) - recv 0" << std::endl; // Send
return;
}
buf_len = send(receiver_s, out_buf, buf_len, 0); buf_len = send(receiver_s, out_buf, buf_len, 0);
std::cout << "LOG (info) - proxy packet send size: " << buf_len << std::endl; if (buf_len == 96) { break; }
} while (buf_len == BUF_SIZE); std::cout << "LOG (info) - proxy packet send size: " << buf_len << '\n';
} while ((buf_len == BUF_SIZE) || (buf_len == 40));
std::cout << "Sent to browser" << std::endl; std::cout << "Sent to browser" << std::endl;
close(sender_s); close(sender_s);
close(receiver_s); close(receiver_s);

View File

@ -34,6 +34,7 @@
#include <string.h> // Needed for strcpy() and strlen() #include <string.h> // Needed for strcpy() and strlen()
#include <fcntl.h> // Needed for file i/o constants #include <fcntl.h> // Needed for file i/o constants
#include <sys/stat.h> // Needed for file i/o constants #include <sys/stat.h> // Needed for file i/o constants
#include <errno.h>
#include <future> #include <future>
#include <iostream> #include <iostream>
#include <vector> #include <vector>
@ -154,7 +155,16 @@ void ClientRequest(int client_s) {
do { do {
buf_len = read(fh, out_buf, BUF_SIZE); buf_len = read(fh, out_buf, BUF_SIZE);
buf_len = send(client_s, out_buf, buf_len, 0); buf_len = send(client_s, out_buf, buf_len, 0);
if (buf_len == -1) {
std::cerr << "ERROR (info) - send -1\n";
std::cerr << "File causing error: " << &file_name[1] << '\n';
std::cerr << "Errno: " << errno << '\n';
std::cout << std::endl;
return;
}
std::cout << "LOG (info) - webserver send size: " << buf_len << '\n';
} while (buf_len == BUF_SIZE); } while (buf_len == BUF_SIZE);
std::cout << std::endl;
close(fh); close(fh);
} }
// Close the client socket and end the thread // Close the client socket and end the thread