Python Websocket服務(wù)端通信的使用示例
1、嘮嘮叨叨
最近又回顧了下Websocket,發(fā)現(xiàn)已經(jīng)忘的七七八八了。于是用js寫(xiě)了客戶端,用python寫(xiě)了服務(wù)端,來(lái)復(fù)習(xí)一下這方面的知識(shí)。
WebSocket 是一種標(biāo)準(zhǔn)協(xié)議,用于在客戶端和服務(wù)端之間進(jìn)行雙向數(shù)據(jù)傳輸。但它跟 HTTP 沒(méi)什么關(guān)系,它是基于 TCP 的一種獨(dú)立實(shí)現(xiàn)。
以前客戶端想知道服務(wù)端的處理進(jìn)度,要不停地使用 Ajax 進(jìn)行輪詢,讓瀏覽器隔個(gè)幾秒就向服務(wù)器發(fā)一次請(qǐng)求,這對(duì)服務(wù)器壓力較大。另外一種輪詢就是采用 long poll 的方式,這就跟打電話差不多,沒(méi)收到消息就一直不掛電話,也就是說(shuō),客戶端發(fā)起連接后,如果沒(méi)消息,就一直不返回 Response 給客戶端,連接階段一直是阻塞的。
而 WebSocket 解決了 HTTP 的這幾個(gè)難題。當(dāng)服務(wù)器完成協(xié)議升級(jí)后( HTTP -> WebSocket ),服務(wù)端可以主動(dòng)推送信息給客戶端,解決了輪詢?cè)斐傻耐窖舆t問(wèn)題。由于 WebSocket 只需要一次 HTTP 握手,服務(wù)端就能一直與客戶端保持通信,直到關(guān)閉連接,這樣就解決了服務(wù)器需要反復(fù)解析 HTTP 協(xié)議,減少了資源的開(kāi)銷。
2、先看一下效果吧
2.1、效果1(一個(gè)客戶端連上服務(wù)的并發(fā)送消息)
2.2、效果2(另一個(gè)客戶端連上服務(wù)的并發(fā)送消息)
2.3、效果3(服務(wù)的收到客戶端的全部消息并返回消息)
2.4、效果4(一個(gè)客戶端掉線并不影響其它socket連接)
2.5、效果5(列取全部連接客戶端對(duì)象和當(dāng)前發(fā)消息的客戶端對(duì)象)
3、核心代碼
3.1、Python
#! -*- coding: utf-8 -*- """ Author: ZhenYuSha Create Time: 2019-1-14 Info: Websocket 的使用示例 """ import asyncio import websockets websocket_users = set() # 檢測(cè)客戶端權(quán)限,用戶名密碼通過(guò)才能退出循環(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) # 接收客戶端消息并處理,這里只是簡(jiǎn)單把客戶端發(fā)來(lái)的返回回去 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) # 鏈接斷開(kāi) print("websocket_users old:", websocket_users) websocket_users.remove(websocket) print("websocket_users new:", websocket_users) break except websockets.InvalidState: print("InvalidState...") # 無(wú)效狀態(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("連接成功, 請(qǐng)輸入賬號(hào)和密碼"); }; ws.onmessage = function(evt) { var received_msg = evt.data; document.getElementById("showMes").value+=received_msg+"\n"; }; ws.onclose = function() { alert("斷開(kāi)了連接"); }; } else { alert("瀏覽器不支持WebSocket"); } function sendMeg(){ var message=document.getElementById("name").value+":"+document.getElementById("mes").value; document.getElementById("showMes").value+=message+"\n\n"; 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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python中使用websocket方法實(shí)例詳解
- 使用python構(gòu)建WebSocket客戶端的教程詳解
- python使用websocket庫(kù)發(fā)送WSS請(qǐng)求
- Python中使用dwebsocket實(shí)現(xiàn)后端數(shù)據(jù)實(shí)時(shí)刷新
- 使用Python創(chuàng)建websocket服務(wù)端并給出不同客戶端的請(qǐng)求
- python開(kāi)發(fā)實(shí)例之python使用Websocket庫(kù)開(kāi)發(fā)簡(jiǎn)單聊天工具實(shí)例詳解(python+Websocket+JS)
- Python如何使用WebSocket實(shí)現(xiàn)實(shí)時(shí)Web應(yīng)用
相關(guān)文章
基于Django實(shí)現(xiàn)日志記錄報(bào)錯(cuò)信息
這篇文章主要介紹了基于Django實(shí)現(xiàn)日志記錄報(bào)錯(cuò)信息,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12Python?pandas數(shù)據(jù)預(yù)處理之行數(shù)據(jù)復(fù)制方式
這篇文章主要介紹了Python?pandas數(shù)據(jù)預(yù)處理之行數(shù)據(jù)復(fù)制方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02關(guān)于CUDA out of memory的解決方案
這篇文章主要介紹了關(guān)于CUDA out of memory的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02Python3 執(zhí)行系統(tǒng)命令并獲取實(shí)時(shí)回顯功能
這篇文章主要介紹了Python3 執(zhí)行系統(tǒng)命令并獲取實(shí)時(shí)回顯功能,文中通過(guò)兩種方法給大家介紹了Python執(zhí)行系統(tǒng)命令并獲得輸出的方法,需要的朋友可以參考下2019-07-07Python 模擬生成動(dòng)態(tài)產(chǎn)生驗(yàn)證碼圖片的方法
這篇文章主要介紹了Python 模擬生成動(dòng)態(tài)產(chǎn)生驗(yàn)證碼圖片的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02詳解Django的model查詢操作與查詢性能優(yōu)化
這篇文章主要介紹了詳解Django的model查詢操作與查詢性能優(yōu)化,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10Jinja2過(guò)濾器的使用、控制語(yǔ)句示例詳解
在Python中,如果需要對(duì)某個(gè)變量進(jìn)行處理,我們可以通過(guò)函數(shù)來(lái)實(shí)現(xiàn),這篇文章主要介紹了Jinja2過(guò)濾器的使用、控制語(yǔ)句,需要的朋友可以參考下2023-03-03pycharm中cv2的package安裝失敗問(wèn)題及解決
這篇文章主要介紹了pycharm中cv2的package安裝失敗問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05Python實(shí)現(xiàn)的讀取/更改/寫(xiě)入xml文件操作示例
這篇文章主要介紹了Python實(shí)現(xiàn)的讀取/更改/寫(xiě)入xml文件操作,涉及Python針對(duì)xml文件的讀取、節(jié)點(diǎn)操作、寫(xiě)入等相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-08-08