搜尋
首頁後端開發Python教學Python中Tornado下WebSocket客戶端程式設計的介紹

這篇文章帶給大家的內容是關於Python中Tornado下WebSocket客戶端程式設計的介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

由於WebSocket是HTML5的標準之一,所以主流瀏覽器的Web客戶端程式設計語音JavaScript已經支援WebSocket的客戶端程式設計。

客戶端程式設計圍繞著WebSocket物件展開,在JavaScript中可以透過以下程式碼初始化WebSocket物件:

var Socket=new WebSocket(url);

在程式碼中只需給WebSocket建構函式傳入伺服器的URL位址,例如http://mysite.com/point.

可以為該物件的以下事件指定處理函數以對應它們:

  • WebSocket.onopen:此事件發生在WebSocket連結建立時。

  • WebSocket.onmessage:此事件發生在收到了來自伺服器的訊息時。

  • WebSocket.onerror:此事件發生在通訊過程中有任何錯誤時。

  • WebSocket.onclose:此事件發生在伺服器的連結關閉時。

除了這些事件處理函數,還可以透過WebSocket物件的兩個方法進行主動操作:

  • WebSocket.send(data):向伺服器發送訊息。

  • WebSocket.close():主動關閉現有連結。

客戶端WebSocket程式設計實例程式如下:index.html

nbsp;html>


    <meta>
    <title>WebSocket</title>


<a>运行WebSocket</a>
<p></p>


<script>
    var messageContainer=document.getElementById("messages");
    function WebSocketTest() {
        if("WebSocket" in window){
            messageContainer.innerHTML="浏览器支持WebSocket";
            var ws=new WebSocket("ws://localhost:8888/websocket?Id=12345");
            ws.onopen=function () {
                ws.send("onopen")
            };
            ws.onmessage=function (evt) {
                var received_msg=evt.data;
                messageContainer.innerHTML=messageContainer.innerHTML+"<br/>收到的信息:"+received_msg;
            }
            ws.onclose=function () {
                messageContainer.innerHTML=messageContainer.innerHTML+"<br/> 连接关闭了";
            }


        }else{
            messageContainer.innerHTML="浏览器不支持WebSocket"
        }
    }
</script>

對上述程式碼解析如下:

  • 客戶端頁面主體是有兩個部分組成:一個Run WebSocket連結用來讓使用者啟動WebSocket;另一個id=message的

    標籤用來顯示伺服器端的訊息。

  • 使用JavaScript語句if("WebSocket" in window)可以判斷目前瀏覽器是否支援WebSocket物件。

  • 如何瀏覽器支援WebSocket對象,則定義實例ws連結到伺服器的WebSocket位址,並傳入自己的識別碼參數。然後透過js語法定義事件:onopen、onmessage、onclose的處理函數。除了在onopen事件中客戶端向伺服器用WebSocket.send()函數發送了訊息,其餘事件均只將事件結果顯示在頁面

    標籤中。

運行效果如下:

Python中Tornado下WebSocket客戶端程式設計的介紹

#

以上是Python中Tornado下WebSocket客戶端程式設計的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault思否。如有侵權,請聯絡admin@php.cn刪除
您如何切成python陣列?您如何切成python陣列?May 01, 2025 am 12:18 AM

Python列表切片的基本語法是list[start:stop:step]。 1.start是包含的第一個元素索引,2.stop是排除的第一個元素索引,3.step決定元素之間的步長。切片不僅用於提取數據,還可以修改和反轉列表。

在什麼情況下,列表的表現比數組表現更好?在什麼情況下,列表的表現比數組表現更好?May 01, 2025 am 12:06 AM

ListSoutPerformarRaysin:1)DynamicsizicsizingandFrequentInsertions/刪除,2)儲存的二聚體和3)MemoryFeliceFiceForceforseforsparsedata,butmayhaveslightperformancecostsinclentoperations。

如何將Python數組轉換為Python列表?如何將Python數組轉換為Python列表?May 01, 2025 am 12:05 AM

toConvertapythonarraytoalist,usEthelist()constructororageneratorexpression.1)intimpthearraymoduleandcreateanArray.2)USELIST(ARR)或[XFORXINARR] to ConconverTittoalist,請考慮performorefformanceandmemoryfformanceandmemoryfformienceforlargedAtasetset。

當Python中存在列表時,使用數組的目的是什麼?當Python中存在列表時,使用數組的目的是什麼?May 01, 2025 am 12:04 AM

choosearraysoverlistsinpythonforbetterperformanceandmemoryfliceSpecificScenarios.1)largenumericaldatasets:arraysreducememoryusage.2)績效 - 臨界雜貨:arraysoffersoffersOffersOffersOffersPoostSfoostSforsssfortasssfortaskslikeappensearch orearch.3)testessenforcety:arraysenforce:arraysenforc

說明如何通過列表和數組的元素迭代。說明如何通過列表和數組的元素迭代。May 01, 2025 am 12:01 AM

在Python中,可以使用for循環、enumerate和列表推導式遍歷列表;在Java中,可以使用傳統for循環和增強for循環遍歷數組。 1.Python列表遍歷方法包括:for循環、enumerate和列表推導式。 2.Java數組遍歷方法包括:傳統for循環和增強for循環。

什麼是Python Switch語句?什麼是Python Switch語句?Apr 30, 2025 pm 02:08 PM

本文討論了版本3.10中介紹的Python的新“匹配”語句,該語句與其他語言相同。它增強了代碼的可讀性,並為傳統的if-elif-el提供了性能優勢

Python中有什麼例外組?Python中有什麼例外組?Apr 30, 2025 pm 02:07 PM

Python 3.11中的異常組允許同時處理多個異常,從而改善了並發方案和復雜操作中的錯誤管理。

Python中的功能註釋是什麼?Python中的功能註釋是什麼?Apr 30, 2025 pm 02:06 PM

Python中的功能註釋將元數據添加到函數中,以進行類型檢查,文檔和IDE支持。它們增強了代碼的可讀性,維護,並且在API開發,數據科學和圖書館創建中至關重要。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境