首頁 php框架 Swoole 如何使用Swoole實作WebSocket伺服器與資料庫交互

如何使用Swoole實作WebSocket伺服器與資料庫交互

Nov 07, 2023 am 09:32 AM
資料庫 websocket swoole

如何使用Swoole實作WebSocket伺服器與資料庫交互

如何使用Swoole實作WebSocket伺服器與資料庫互動

#簡介:
WebSocket是一種基於TCP協定的全雙工通訊協議,可以在客戶端與伺服器之間建立即時的雙向通訊。而Swoole是一款PHP擴展,可輕鬆實現高效能的非同步、並發程式設計。在本文中,我們將詳細介紹如何使用Swoole來建立WebSocket伺服器,並實現與資料庫的互動。

步驟一:安裝Swoole擴充功能

首先,我們需要安裝Swoole擴充功能。可以透過以下命令來安裝:

pecl install swoole
登入後複製

步驟二:建立WebSocket伺服器

#接下來,我們建立一個WebSocket伺服器,監聽指定的端口,並建立與客戶端的連線。可以使用以下程式碼來實作:

<?php
$server = new SwooleWebSocketServer("0.0.0.0", 9501);

$server->on('open', function (SwooleWebSocketServer $server, $request) {
    echo "new connection open: {$request->fd}
";
});

$server->on('message', function (SwooleWebSocketServer $server, $frame) {
    echo "received message: {$frame->data}
";
    
    // 处理数据库交互
    $db = new mysqli('localhost', 'username', 'password', 'database');
    $result = $db->query("SELECT * FROM users");
    while ($row = $result->fetch_assoc()) {
        $server->push($frame->fd, json_encode($row));
    }
    $db->close();
});

$server->on('close', function ($ser, $fd) {
    echo "connection close: {$fd}
";
});

$server->start();
?>
登入後複製

在上述程式碼中,我們建立了一個WebSocket伺服器,並新增了三個事件回呼函數。當有連接建立時,open事件將被觸發;當收到訊息時,message事件將被觸發;當連接關閉時,close事件將被觸發。在message事件中,我們可以進行資料庫的互動操作。

步驟三:與資料庫互動

message事件回呼函數中,我們使用了MySQLi擴充來與資料庫互動。首先,我們建立了一個$db對象,並使用mysqli的建構子連接到資料庫。接著,我們執行了一條查詢語句,並透過while循環將查詢結果傳送給客戶端。最後,我們關閉了資料庫連線。

需要注意的是,為了安全起見,我們應該將資料庫的相關資訊(如使用者名稱和密碼)設為環境變量,並透過getenv()函數來取得這些值,以避免直接暴露在程式碼中。

步驟四:執行伺服器

最後,我們使用命令列來執行上述程式碼。在命令列中切換到程式碼所在的目錄,並執行以下命令:

php server.php
登入後複製

如果一切正常,你將看到WebSocket伺服器成功啟動,並等待客戶端的連線。當有客戶端連接到伺服器時,open事件將被觸發,並在命令列中顯示連接的ID。當收到客戶端發送的訊息時,message事件將被觸發,並在命令列中顯示收到的訊息。當連線關閉時,close事件將會觸發,同樣在命令列中顯示連線的關閉。

總結:
本文詳細介紹如何使用Swoole實作WebSocket伺服器與資料庫的互動。透過建立WebSocket伺服器,並在message事件回呼函數中進行資料庫的互動操作,我們可以實現即時的雙向通訊。使用Swoole擴展,我們可以輕鬆地進行高效能的非同步、並發程式設計。希望本文對你在使用Swoole與資料庫互動方面有所幫助。

以上是如何使用Swoole實作WebSocket伺服器與資料庫交互的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

SSE 與 WebSocket SSE 與 WebSocket Apr 17, 2024 pm 02:18 PM

在本文中,我們將比較伺服器發送事件(SSE)和 WebSocket,兩者都是用於傳遞資料的可靠方法。我們將在八個方面對它們進行分析,包括通訊方向、底層協定、安全性、易用性、效能、訊息結構、易用性和測試工具。這些方面的比較總結如下:類別伺服器發送事件(SSE)WebSocket通訊方向單向雙向底層協定HTTPWebSocket 協定安全性與HTTP 相同存在安全漏洞易用性設定簡單設定複雜效能訊息傳送速度快受訊息處理和連線管理影響訊息結構純文字文字或二進位易用性廣泛可用對WebSocket 整合有

swoole和workerman哪個好 swoole和workerman哪個好 Apr 09, 2024 pm 07:00 PM

Swoole 和 Workerman 都是高效能 PHP 伺服器框架。 Swoole 以其非同步處理、出色的效能和可擴展性而聞名,適用於需要處理大量並發請求和高吞吐量的專案。 Workerman 提供了非同步和同步模式的靈活性,具有直覺的 API,更適合易用性和處理較低並發量的專案。

Hibernate 如何實作多型映射? Hibernate 如何實作多型映射? Apr 17, 2024 pm 12:09 PM

Hibernate多態映射可映射繼承類別到資料庫,提供以下映射類型:joined-subclass:為子類別建立單獨表,包含父類別所有欄位。 table-per-class:為子類別建立單獨資料表,僅包含子類別特有列。 union-subclass:類似joined-subclass,但父類別表聯合所有子類別列。

iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 Jul 18, 2024 am 05:48 AM

蘋果公司最新發布的iOS18、iPadOS18以及macOSSequoia系統為Photos應用程式增添了一項重要功能,旨在幫助用戶輕鬆恢復因各種原因遺失或損壞的照片和影片。這項新功能在Photos應用的"工具"部分引入了一個名為"已恢復"的相冊,當用戶設備中存在未納入其照片庫的圖片或影片時,該相冊將自動顯示。 "已恢復"相簿的出現為因資料庫損壞、相機應用未正確保存至照片庫或第三方應用管理照片庫時照片和視頻丟失提供了解決方案。使用者只需簡單幾步

swoole和java哪個表現好 swoole和java哪個表現好 Apr 09, 2024 pm 07:03 PM

效能比較:吞吐量:Swoole 以協程機制,吞吐量更高。延遲:Swoole 的協程上下文切換開銷更低,延遲更小。記憶體消耗:Swoole 的協程佔用記憶體較少。易用性:Swoole 提供更易於使用的並發程式設計 API。

在PHP中使用MySQLi建立資料庫連線的詳盡教學 在PHP中使用MySQLi建立資料庫連線的詳盡教學 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立資料庫連線:包含MySQLi擴充(require_once)建立連線函數(functionconnect_to_db)呼叫連線函數($conn=connect_to_db())執行查詢($result=$conn->query())關閉連線( $conn->close())

如何在PHP中處理資料庫連線錯誤 如何在PHP中處理資料庫連線錯誤 Jun 05, 2024 pm 02:16 PM

PHP處理資料庫連線報錯,可以使用下列步驟:使用mysqli_connect_errno()取得錯誤代碼。使用mysqli_connect_error()取得錯誤訊息。透過擷取並記錄這些錯誤訊息,可以輕鬆識別並解決資料庫連接問題,確保應用程式的順暢運作。

swoole協程是怎樣調度的 swoole協程是怎樣調度的 Apr 09, 2024 pm 07:06 PM

Swoole協程是一種輕量級並發函式庫,可讓開發者編寫並發程式。 Swoole協程調度機制基於協程模式和事件循環,使用協程堆疊管理協程執行,在協程讓出控制權後掛起它們。事件循環處理IO和定時器事件,協程讓出控制權時被掛起並返回事件循環。當事件發生時,Swoole從事件循環切換到掛起的協程,透過儲存和載入協程狀態完成切換。協程調度使用優先權機制,支援掛起、休眠和復原作業以靈活控制協程執行。

See all articles