Python Websocket服務(wù)端通信的使用示例
1、嘮嘮叨叨
最近又回顧了下Websocket,發(fā)現(xiàn)已經(jīng)忘的七七八八了。于是用js寫了客戶端,用python寫了服務(wù)端,來復(fù)習(xí)一下這方面的知識。
WebSocket 是一種標(biāo)準(zhǔn)協(xié)議,用于在客戶端和服務(wù)端之間進行雙向數(shù)據(jù)傳輸。但它跟 HTTP 沒什么關(guān)系,它是基于 TCP 的一種獨立實現(xiàn)。
以前客戶端想知道服務(wù)端的處理進度,要不停地使用 Ajax 進行輪詢,讓瀏覽器隔個幾秒就向服務(wù)器發(fā)一次請求,這對服務(wù)器壓力較大。另外一種輪詢就是采用 long poll 的方式,這就跟打電話差不多,沒收到消息就一直不掛電話,也就是說,客戶端發(fā)起連接后,如果沒消息,就一直不返回 Response 給客戶端,連接階段一直是阻塞的。
而 WebSocket 解決了 HTTP 的這幾個難題。當(dāng)服務(wù)器完成協(xié)議升級后( HTTP -> WebSocket ),服務(wù)端可以主動推送信息給客戶端,解決了輪詢造成的同步延遲問題。由于 WebSocket 只需要一次 HTTP 握手,服務(wù)端就能一直與客戶端保持通信,直到關(guān)閉連接,這樣就解決了服務(wù)器需要反復(fù)解析 HTTP 協(xié)議,減少了資源的開銷。
2、先看一下效果吧
2.1、效果1(一個客戶端連上服務(wù)的并發(fā)送消息)
2.2、效果2(另一個客戶端連上服務(wù)的并發(fā)送消息)
2.3、效果3(服務(wù)的收到客戶端的全部消息并返回消息)
2.4、效果4(一個客戶端掉線并不影響其它socket連接)
2.5、效果5(列取全部連接客戶端對象和當(dāng)前發(fā)消息的客戶端對象)
3、核心代碼
3.1、Python
#! -*- coding: utf-8 -*-'''Author: ZhenYuShaCreate Time: 2019-1-14Info: Websocket 的使用示例'''import asyncioimport websocketswebsocket_users = set()# 檢測客戶端權(quán)限,用戶名密碼通過才能退出循環(huán)async def check_user_permit(websocket): print('new websocket_users:', websocket) websocket_users.add(websocket) print('websocket_users list:', websocket_users) while True: recv_str = await websocket.recv() cred_dict = recv_str.split(':') if cred_dict[0] == 'admin' and cred_dict[1] == '123456': response_str = 'Congratulation, you have connect with server...' await websocket.send(response_str) print('Password is ok...') return True else: response_str = 'Sorry, please input the username or password...' print('Password is wrong...') await websocket.send(response_str)# 接收客戶端消息并處理,這里只是簡單把客戶端發(fā)來的返回回去async def recv_user_msg(websocket): while True: recv_text = await websocket.recv() print('recv_text:', websocket.pong, recv_text) response_text = f'Server return: {recv_text}' print('response_text:', response_text) await websocket.send(response_text)# 服務(wù)器端主邏輯async def run(websocket, path): while True: try: await check_user_permit(websocket) await recv_user_msg(websocket) except websockets.ConnectionClosed: print('ConnectionClosed...', path) # 鏈接斷開 print('websocket_users old:', websocket_users) websocket_users.remove(websocket) print('websocket_users new:', websocket_users) break except websockets.InvalidState: print('InvalidState...') # 無效狀態(tài) break except Exception as e: print('Exception:', e)if __name__ == ’__main__’: print('127.0.0.1:8181 websocket...') asyncio.get_event_loop().run_until_complete(websockets.serve(run, '127.0.0.1', 8181)) asyncio.get_event_loop().run_forever()
3.2、Html(JS)
<script> var socket; if ('WebSocket' in window) { var ws = new WebSocket('ws://127.0.0.1:8181/test'); socket = ws; ws.onopen = function() { console.log(’連接成功’); alert('連接成功, 請輸入賬號和密碼'); }; ws.onmessage = function(evt) { var received_msg = evt.data; document.getElementById('showMes').value+=received_msg+'n'; }; ws.onclose = function() { alert('斷開了連接'); }; } else { alert('瀏覽器不支持WebSocket'); } function sendMeg(){ var message=document.getElementById('name').value+':'+document.getElementById('mes').value; document.getElementById('showMes').value+=message+'nn'; socket.send(message); } </script>
4、Github源碼分享
https://github.com/ShaShiDiZhuanLan/Demo_Socket_Python
到此這篇關(guān)于Python Websocket服務(wù)端通信的使用示例的文章就介紹到這了,更多相關(guān)Python Websocket服務(wù)端通信內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
