First of all, I'm using this piece of PHP code (a basic talkback server copied from https://www.php.net/manual/en/sockets.examples.php) to handle the websocket:
<?php
error_reporting(E_ALL);
/* Allow the script to hang around waiting for connections. */
set_time_limit(0);
/* Turn on implicit output flushing so we see what we're getting
* as it comes in. */
ob_implicit_flush();
$address = "127.0.0.1";
$port = 3547;
if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) === false) {
echo "socket_create() failed: reason: " . socket_strerror(socket_last_error()) . "\n";
}
if (socket_bind($sock, $address, $port) === false) {
echo "socket_bind() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
}
if (socket_listen($sock, 5) === false) {
echo "socket_listen() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
}
do {
if (($msgsock = socket_accept($sock)) === false) {
echo "socket_accept() failed: reason: " . socket_strerror(socket_last_error($sock)) . "\n";
break;
}
/* Send instructions. */
$msg = "\nWelcome to the PHP Test Server. \n" .
"To quit, type 'quit'. To shut down the server type 'shutdown'.\n";
socket_write($msgsock, $msg, strlen($msg));
do {
if (false === ($buf = socket_read($msgsock, 2048, PHP_NORMAL_READ))) {
echo "socket_read() failed: reason: " . socket_strerror(socket_last_error($msgsock)) . "\n";
break 2;
}
if (!$buf = trim($buf)) {
continue;
}
if ($buf == 'quit') {
break;
}
if ($buf == 'shutdown') {
socket_close($msgsock);
break 2;
}
$talkback = "PHP: You said '$buf'.\n";
socket_write($msgsock, $talkback, strlen($talkback));
echo "$buf\n";
} while (true);
socket_close($msgsock);
} while (true);
socket_close($sock);
?>
And this piece of JavaScript code to handle the connecting to the websocket:
$(window).on("load", () => {
let exampleSocket = new WebSocket("ws://127.0.0.1:3547");
exampleSocket.onopen = (e) => {
console.log("connected!");
exampleSocket.send("first");
setTimeout(() => {
exampleSocket.send("second");
}, 2000);
setTimeout(() => {
exampleSocket.send("third");
}, 4000);
setTimeout(() => {
exampleSocket.send("fourth");
}, 6000);
};
exampleSocket.onmessage = (e) => {
console.log("from server: " + event.data);
};
});
After running that PHP script in my local command line to get the websocket open and refreshing the webpage that is pulling that script, I get this JavaScript error within my console in my browser: WebSocket connection to 'ws://127.0.0.1:3547/' failed: Error during WebSocket handshake: net::ERR_INVALID_HTTP_RESPONSE
and this PHP error in my command line window: socket_read(): unable to read from socket [10053]: An established connection was aborted by the software in your host machine.
.
I've already done a little bit of research on this issue but I've found no posts that specifically mentioned that the server was running on a local Apache server (which I'm not sure if that's causing the issue or not).
Any ideas?