web sockets
A websocket is a persistent connection between your browser and the server that messages can be sent across. Using a websocket connection allows a server to "push" notifications to the client seamlessly, rather than the client polling for updates:data:image/s3,"s3://crabby-images/c6da9/c6da9a131c256664c06880e1c7e2a37bca1492a7" alt=""
sockets.py
from flask import Flask, render_template_string from flask_socketio import SocketIO, send, emit app = Flask(__name__) socketio = SocketIO(app) tickets = 20 output = ''' <script src="https://cdn.socket.io/socket.io-1.0.0.js"></script> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script> var socket = io.connect("http://127.0.0.1:5000"); socket.on('connect', function() { document.title = "Connected"; }); //************* TICKET TAKEN BY ANOTHER USER: socket.on('available', function(tickets) { document.getElementById("ticks").innerHTML = tickets; }); //************* SEND A MESSAGE TO THE SERVER: $(document).ready( function() { $('.gday' ).click(function() { socket.emit("ClientToServer", "gday mate"); }); }); </script> tickets remaining: <span id='ticks'>{{ tickets }}</span><br> <a href='/buy'>claim one!</a><br> <button class='gday'>send msg to server</button><br> ''' @app.route('/') def index(): global tickets return render_template_string(output, tickets = tickets) @app.route('/buy') def ticketSold(): global tickets tickets -= 1 socketio.emit('available',tickets) return render_template_string(output, tickets = tickets) @socketio.on('ClientToServer') def handle(msg): print('received msg: ' + msg) socketio.run(app)
Installing Web Sockets
To install sockets on Windows, first install Microsoft Visual C++ 14.0 (found in Microsoft Visual C++ Build Tools):data:image/s3,"s3://crabby-images/3df8c/3df8cfddbdb278bdc6a1964ba041832ad1de12e3" alt=""
Then install flask socketio:
pip3 install flask-socketio
data:image/s3,"s3://crabby-images/f7020/f7020e7b8facc39769c4af8f466ec3bcca431604" alt=""
Allow connections through Windows firewall:
data:image/s3,"s3://crabby-images/6f29d/6f29d9905b2df46132fea86d076dfe2311746e10" alt=""
To install sockets on Mac:
data:image/s3,"s3://crabby-images/d96f7/d96f781a31445ff49cb3be9d4f8152f013c4dece" alt=""
... which will trigger the xcode developer tools download ...
data:image/s3,"s3://crabby-images/38529/38529ef7328af52cb8538adc9e9d4a64cce469bd" alt=""
once xcode developer tools have installed, reinstall gevent if it didn't finish properly before:
data:image/s3,"s3://crabby-images/d96f7/d96f781a31445ff49cb3be9d4f8152f013c4dece" alt=""
finally, pip3 install flask-socketio, as above:
data:image/s3,"s3://crabby-images/489a8/489a8fa872db144c9b4d66302871b38427bf2db7" alt=""