欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中實(shí)現(xiàn)WebSocket的示例詳解

 更新時(shí)間:2025年03月10日 15:59:27   作者:王子良.  
WebSocket 是一種計(jì)算機(jī)通信協(xié)議,它為客戶端和服務(wù)器之間的雙向通信提供了一個(gè)全雙工的通道,本篇文章將詳解 Python 中如何實(shí)現(xiàn) WebSocket,感興趣的可以了解下

WebSocket 是一種計(jì)算機(jī)通信協(xié)議,它為客戶端和服務(wù)器之間的雙向通信提供了一個(gè)全雙工的通道。通過(guò) WebSocket,客戶端和服務(wù)器可以在一個(gè)長(zhǎng)期的連接中保持通信,而無(wú)需每次都建立新的連接。這個(gè)特性在實(shí)時(shí)聊天、在線游戲、股票行情等應(yīng)用中非常有用。

本篇文章將詳解 Python 中如何實(shí)現(xiàn) WebSocket,內(nèi)容包括 WebSocket 的基礎(chǔ)概念、Python 中的 WebSocket 庫(kù)、簡(jiǎn)單的客戶端和服務(wù)器端代碼示例、以及一些高級(jí)使用場(chǎng)景。

1. WebSocket 基礎(chǔ)概念

WebSocket 協(xié)議最初是由 IETF(Internet Engineering Task Force)發(fā)布的,目的是提供一個(gè)更高效的通信協(xié)議,可以通過(guò)單個(gè)長(zhǎng)連接在客戶端和服務(wù)器之間進(jìn)行雙向通信。WebSocket 的通信通過(guò)在 HTTP 協(xié)議上建立一個(gè)持久連接(即 WebSocket 握手),并且支持全雙工通信,即數(shù)據(jù)可以同時(shí)從客戶端發(fā)送到服務(wù)器,也可以從服務(wù)器發(fā)送到客戶端。

WebSocket 與傳統(tǒng)的 HTTP 協(xié)議有很大的不同。HTTP 是一個(gè)請(qǐng)求-響應(yīng)式的協(xié)議,客戶端每次需要獲取數(shù)據(jù)時(shí)都需要向服務(wù)器發(fā)送請(qǐng)求,而 WebSocket 則是通過(guò)一個(gè)初始握手請(qǐng)求將通信通道建立起來(lái),之后雙方可以隨時(shí)發(fā)送數(shù)據(jù)。

WebSocket 握手過(guò)程:

  • 客戶端向服務(wù)器發(fā)起一個(gè) HTTP 請(qǐng)求,并要求升級(jí)到 WebSocket 協(xié)議。
  • 服務(wù)器響應(yīng)客戶端的請(qǐng)求,確認(rèn)升級(jí)協(xié)議。
  • 客戶端和服務(wù)器建立 WebSocket 連接,可以開(kāi)始全雙工通信。

2. Python WebSocket 庫(kù)

在 Python 中,我們通常使用以下幾種庫(kù)來(lái)實(shí)現(xiàn) WebSocket:

  • websockets:一個(gè)輕量級(jí)的 Python WebSocket 實(shí)現(xiàn),支持異步編程。
  • socket.io:一個(gè)更為高級(jí)的庫(kù),支持事件驅(qū)動(dòng)和自動(dòng)重連等特性,常用于實(shí)時(shí)應(yīng)用。
  • asyncio:雖然 asyncio 本身并不是一個(gè) WebSocket 庫(kù),但它為 WebSocket 的異步編程提供了基礎(chǔ)支持。

在本篇文章中,我們將主要介紹 websockets 庫(kù),并使用它來(lái)實(shí)現(xiàn) WebSocket 客戶端和服務(wù)器。

3. 安裝 websockets 庫(kù)

在使用 websockets 庫(kù)之前,我們需要先安裝它??梢酝ㄟ^(guò) pip 來(lái)安裝:

pip install websockets

4. WebSocket 服務(wù)器端實(shí)現(xiàn)

創(chuàng)建 WebSocket 服務(wù)器

WebSocket 服務(wù)器通常運(yùn)行在一個(gè)特定的端口,并等待客戶端的連接請(qǐng)求。我們可以通過(guò) websockets 庫(kù)來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 WebSocket 服務(wù)器。

import asyncio
import websockets
 
async def handle_connection(websocket, path):
    # 接收到客戶端的消息
    print(f"Connected to {websocket.remote_address}")
    try:
        async for message in websocket:
            print(f"Received message: {message}")
            # 發(fā)送消息回客戶端
            await websocket.send(f"Server received: {message}")
    except Exception as e:
        print(f"Error: {e}")
    finally:
        print(f"Disconnected from {websocket.remote_address}")
 
async def main():
    # 啟動(dòng) WebSocket 服務(wù)器,監(jiān)聽(tīng) 8765 端口
    server = await websockets.serve(handle_connection, "localhost", 8765)
    print("WebSocket server started on ws://localhost:8765")
    await server.wait_closed()
 
# 啟動(dòng)事件循環(huán)
asyncio.run(main())

代碼說(shuō)明

handle_connection 是處理每個(gè)客戶端連接的異步函數(shù)。每當(dāng)有客戶端連接時(shí),服務(wù)器將接收到的消息打印出來(lái),并將消息返回給客戶端。

websockets.serve() 用于啟動(dòng) WebSocket 服務(wù)器,監(jiān)聽(tīng)指定的地址和端口(此處為 localhost 和 8765)。

await server.wait_closed() 保證服務(wù)器持續(xù)運(yùn)行,直到手動(dòng)關(guān)閉。

5. WebSocket 客戶端實(shí)現(xiàn)

創(chuàng)建 WebSocket 客戶端

WebSocket 客戶端用于與服務(wù)器建立連接,并發(fā)送和接收消息。我們使用 websockets.connect 來(lái)連接到服務(wù)器。

import asyncio
import websockets
 
async def send_message():
    uri = "ws://localhost:8765"
    async with websockets.connect(uri) as websocket:
        # 向服務(wù)器發(fā)送消息
        await websocket.send("Hello, Server!")
        print("Message sent to server.")
        
        # 接收服務(wù)器返回的消息
        response = await websocket.recv()
        print(f"Received from server: {response}")
 
# 啟動(dòng)事件循環(huán)
asyncio.run(send_message())

代碼說(shuō)明

websockets.connect(uri) 用于與 WebSocket 服務(wù)器建立連接。uri 是服務(wù)器的地址,此處為 ws://localhost:8765。

使用 await websocket.send() 向服務(wù)器發(fā)送消息。

使用 await websocket.recv() 接收來(lái)自服務(wù)器的消息。

6. 異常處理

在實(shí)際應(yīng)用中,WebSocket 連接可能會(huì)因?yàn)榫W(wǎng)絡(luò)中斷、服務(wù)器關(guān)閉等原因而失敗。我們可以在客戶端和服務(wù)器端都加入適當(dāng)?shù)漠惓L幚怼?/p>

6.1 客戶端異常處理

async def send_message():
    uri = "ws://localhost:8765"
    try:
        async with websockets.connect(uri) as websocket:
            await websocket.send("Hello, Server!")
            print("Message sent to server.")
            response = await websocket.recv()
            print(f"Received from server: {response}")
    except websockets.exceptions.ConnectionClosed as e:
        print(f"Connection closed: {e}")
    except Exception as e:
        print(f"Error: {e}")
 
asyncio.run(send_message())

6.2 服務(wù)器端異常處理

async def handle_connection(websocket, path):
    print(f"Connected to {websocket.remote_address}")
    try:
        async for message in websocket:
            print(f"Received message: {message}")
            await websocket.send(f"Server received: {message}")
    except websockets.exceptions.ConnectionClosed as e:
        print(f"Connection closed: {e}")
    except Exception as e:
        print(f"Error: {e}")
    finally:
        print(f"Disconnected from {websocket.remote_address}")

7. WebSocket 高級(jí)使用

7.1. 廣播消息

如果你想讓服務(wù)器向所有已連接的客戶端廣播消息,可以維護(hù)一個(gè)客戶端列表并發(fā)送消息。

clients = set()
 
async def handle_connection(websocket, path):
    clients.add(websocket)
    try:
        async for message in websocket:
            print(f"Received message: {message}")
            # 廣播消息給所有客戶端
            for client in clients:
                if client != websocket:
                    await client.send(f"Broadcast message: {message}")
    except Exception as e:
        print(f"Error: {e}")
    finally:
        clients.remove(websocket)
        print(f"Disconnected from {websocket.remote_address}")

7.2. 認(rèn)證和授權(quán)

你可以使用 WebSocket 協(xié)議的初始握手階段進(jìn)行認(rèn)證和授權(quán),比如使用 HTTP header 傳遞認(rèn)證信息。

async def handle_connection(websocket, path):
    headers = websocket.request_headers
    token = headers.get('Authorization')
    if token != "expected_token":
        await websocket.send("Unauthorized")
        await websocket.close()
        return
    print(f"Client authorized with token: {token}")
    # 處理正常的消息

8. 總結(jié)

本文詳細(xì)介紹了如何在 Python 中使用 websockets 庫(kù)實(shí)現(xiàn) WebSocket 服務(wù)端和客戶端,涉及到的主要概念包括:

WebSocket 協(xié)議基礎(chǔ)及其優(yōu)勢(shì);

如何實(shí)現(xiàn) WebSocket 服務(wù)器和客戶端;

如何處理異常、進(jìn)行消息廣播和認(rèn)證等高級(jí)應(yīng)用。

以上就是Python中實(shí)現(xiàn)WebSocket的示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Python WebSocket的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解詳解Python中writelines()方法的使用

    詳解詳解Python中writelines()方法的使用

    這篇文章主要介紹了詳解詳解Python中writelines()方法的使用,是Python入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-05-05
  • 加速Python代碼執(zhí)行利器使用實(shí)例探究

    加速Python代碼執(zhí)行利器使用實(shí)例探究

    這篇文章主要為大家介紹了加速Python代碼執(zhí)行的利器使用實(shí)例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-01-01
  • 在Python的web框架中配置app的教程

    在Python的web框架中配置app的教程

    這篇文章主要介紹了在Python的web框架中配置app的教程,代碼基于Python2.x版本,需要的朋友可以參考下
    2015-04-04
  • python實(shí)現(xiàn)支付寶轉(zhuǎn)賬接口

    python實(shí)現(xiàn)支付寶轉(zhuǎn)賬接口

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)支付寶轉(zhuǎn)賬接口,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • Python調(diào)整圖像hue值結(jié)合ImageEnhance庫(kù)以實(shí)現(xiàn)色調(diào)增強(qiáng)

    Python調(diào)整圖像hue值結(jié)合ImageEnhance庫(kù)以實(shí)現(xiàn)色調(diào)增強(qiáng)

    這篇文章主要介紹了Python調(diào)整圖像hue值結(jié)合ImageEnhance庫(kù)以實(shí)現(xiàn)色調(diào)增強(qiáng),PIL庫(kù)中的ImageEnhance類(lèi)可用于圖像增強(qiáng),可以調(diào)節(jié)圖像的亮度、對(duì)比度、色度和銳度,通過(guò)RGB到HSV的變換加調(diào)整可以對(duì)圖像的色調(diào)進(jìn)行調(diào)整,需要的朋友可以參考下
    2023-09-09
  • Python利用臨時(shí)文件實(shí)現(xiàn)數(shù)據(jù)的保存

    Python利用臨時(shí)文件實(shí)現(xiàn)數(shù)據(jù)的保存

    tempfile模塊專(zhuān)門(mén)用于創(chuàng)建臨時(shí)文件和臨時(shí)目錄,它既可以在?UNIX?平臺(tái)上運(yùn)行良好,也可以在?Windows?平臺(tái)上運(yùn)行良好。本文將利用tempfile模塊創(chuàng)建臨時(shí)文件來(lái)保存數(shù)據(jù),感興趣的可以了解一下
    2022-07-07
  • 4種python判斷字符串是否包含關(guān)鍵字的方法

    4種python判斷字符串是否包含關(guān)鍵字的方法

    這篇文章主要為大家詳細(xì)介紹了4種python判斷字符串是否包含關(guān)鍵字的方法,文中的示例代碼講解詳細(xì),有需要的小伙伴可以根據(jù)自己的需求進(jìn)行選擇
    2025-04-04
  • Django serializer優(yōu)化類(lèi)視圖的實(shí)現(xiàn)示例

    Django serializer優(yōu)化類(lèi)視圖的實(shí)現(xiàn)示例

    這篇文章主要介紹了Django serializer優(yōu)化類(lèi)視圖的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Python實(shí)現(xiàn)21點(diǎn)小游戲的示例代碼

    Python實(shí)現(xiàn)21點(diǎn)小游戲的示例代碼

    1931年,當(dāng)美國(guó)內(nèi)華達(dá)州宣布賭博為合法活動(dòng)時(shí),21點(diǎn)游戲第一次公開(kāi)出現(xiàn)在內(nèi)華達(dá)州的賭場(chǎng)俱樂(lè)部,15年內(nèi),它取代擲骰子游戲,而一舉成為非常流行的賭場(chǎng)莊家參與的賭博游戲。本文將用Python實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以了解一下
    2022-09-09
  • python基于Opencv實(shí)現(xiàn)人臉口罩檢測(cè)

    python基于Opencv實(shí)現(xiàn)人臉口罩檢測(cè)

    最近嘗試做一個(gè)python基于Opencv實(shí)現(xiàn)人臉口罩檢測(cè),記錄一下過(guò)程,稍微整理精簡(jiǎn)一下做下分享,需要的小伙伴可以參考下
    2021-06-06

最新評(píng)論