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?
