Einführung in die Kombination von GatewayWorker und ThinkPHP und anderen Frameworks

不言
Freigeben: 2023-04-02 14:40:01
Original
7304 Leute haben es durchsucht

Dieser Artikel stellt hauptsächlich die Kombination von GatewayWorker und ThinkPHP und anderen Frameworks vor. Jetzt kann ich ihn mit Ihnen teilen.

Entwickler sind am meisten besorgt GatewayWorker Das Wichtigste ist die Integration in das vorhandene MVC-Framework (ThinkPHP Yii Laravel usw.). Das Folgende ist die offiziell empfohlene Integrationsmethode.

Siehe Diagramm:

## Allgemeine Grundsätze

VorhandenesMVC-Framework-Projekt und GatewayWorker werden unabhängig voneinander eingesetzt ohne sich gegenseitig zu stören

Die gesamte Geschäftslogik wird vom Website-Seitenbeitrag/Get zum MVC-Framework

GatewayWorker Akzeptiert keine Daten vom Client, d. h. GatewayWorker verarbeitet keine Geschäftslogik, GatewayWorker dient nur als Einseitiger Push-Kanal

Nur ​​wenn mvc FrameworkSie müssen Daten aktiv an den Browser übertragen nur im MVC-Framework Gateways API (GatewayClient) aufrufen um den Push abzuschließen

## Spezifische Implementierungsschritte

1 Website-Seite Einrichtung und GatewayWorkers Websocket-Verbindung

2. GatewayWorker hat festgestellt, dass a Seite hat eine Verbindung initiiert , senden Sie die client_id , die der Verbindung entspricht, an die Website-Seite

3. Die Website-Seite löst eine Ajax-Anfrage aus, nachdem client_id empfangen wurde (vorausgesetzt, es ist )bind.phpClient_ID an MVC-Backend senden

4. MVC-Backend Erhalten Sie client_idbind.php. Verwenden Sie dann GatewayClient, um Gateway::bindUid($client_id, $uid) aufzurufen, um client_id mit zu kombinieren die aktuelle UID(Benutzer-ID oder eindeutige Client-ID) ​​Bindung. Wenn eine Gruppen- oder Massenversandfunktion vorhanden ist, können Sie auch Gateway::joinGroup($client_id, $group_id) verwenden, um die client_id zur entsprechenden Gruppe hinzuzufügen

5 . Alle durch die Seitenanfragen initiierten Nachrichten werden zur einheitlichen Verarbeitung direkt an das MVC-Framework gesendet/abgerufen, einschließlich des Sendens von Nachrichten

6. Während des Geschäftsprozesses des MVC-Frameworks, muss eine bestimmte UID 🎜> senden oder Wenn eine Gruppe Daten sendet , rufen Sie direkt die GatewayClient-Schnittstelle Gateway::sendToUid<span style="color: #ff0000;"><strong><span style="text-decoration: underline;"><span style="color: #000000; text-decoration: underline;">Gateway::sendToUid</span></span> </strong><span style="text-decoration: underline; color: #000000;"><strong>Gateway::sendToGroup</strong></span></span> Gateway::sendToGroup

Auf Senden warten

## Beispielcode

# ## GatewayWorker-Snippet

GatewayWorker Events.php-Code (nur eine onConnect-Rückrufeinstellung)

<?php
use \GatewayWorker\Lib\Gateway;class Events
{    // 当有客户端连接时,将client_id返回,让mvc框架判断当前uid并执行绑定    public static function onConnect($client_id)
    {
        Gateway::sendToClient($client_id, json_encode(array(            &#39;type&#39;      => &#39;init&#39;,            &#39;client_id&#39; => $client_id
        )));
    }    // GatewayWorker建议不做任何业务逻辑,onMessage留空即可    public static function onMessage($client_id, $message)
    {

    }
}
Nach dem Login kopieren

### Website-Seiten-JS-Fragment

/**
 * 与GatewayWorker建立websocket连接,域名和端口改为你实际的域名端口,
 * 其中端口为Gateway端口,即start_gateway.php指定的端口。
 * start_gateway.php 中需要指定websocket协议,像这样
 * $gateway = new Gateway(websocket://0.0.0.0:7272);
 */
ws = new WebSocket("ws://your_domain.com:7272");// 服务端主动推送消息时会触发这里的onmessage
ws.onmessage = function(e){    // json数据转换成js对象    var data = eval("("+e.data+")");    var type = data.type || &#39;&#39;;    switch(type){        // Events.php中返回的init类型的消息,将client_id发给后台进行uid绑定        case &#39;init&#39;:            // 利用jquery发起ajax请求,将client_id发给后端进行uid绑定
            $.post(&#39;./bind.php&#39;, {client_id: data.client_id}, function(data){}, &#39;json&#39;);            break;        // 当mvc框架调用GatewayClient发消息时直接alert出来        default :
            alert(e.data);
    }
};
Nach dem Login kopieren

### MVC-Backend-UID-Bindung Codefragment

<🎜>bind.php (mit GatewayClient binden)<🎜>
<?php//加载GatewayClient。关于GatewayClient参见本页面底部介绍require_once &#39;/your/path/GatewayClient/Gateway.php&#39;;// GatewayClient 3.0.0版本开始要使用命名空间use GatewayClient\Gateway;// 设置GatewayWorker服务的Register服务ip和端口,请根据实际情况改成实际值(ip不能是0.0.0.0)
Gateway::$registerAddress = &#39;127.0.0.1:1236&#39;;// 假设用户已经登录,用户uid和群组id在session中
$uid      = $_SESSION[&#39;uid&#39;];
$group_id = $_SESSION[&#39;group&#39;];// client_id与uid绑定
Gateway::bindUid($client_id, $uid);// 加入某个群组(可调用多次加入多个群组)
Gateway::joinGroup($client_id, $group_id);
Nach dem Login kopieren
<🎜>### MVC-Backend-Nachrichtencode-Snippet<🎜><🎜>send_message.php (mit GatewayClient senden)<🎜>
<?php//加载GatewayClient。关于GatewayClient参见本页面底部介绍require_once &#39;/your/path/GatewayClient/Gateway.php&#39;;// GatewayClient 3.0.0版本开始要使用命名空间use GatewayClient\Gateway;// 设置GatewayWorker服务的Register服务ip和端口,请根据实际情况改成实际值(ip不能是0.0.0.0)
Gateway::$registerAddress = &#39;127.0.0.1:1236&#39;;// 向任意uid的网站页面发送数据
Gateway::sendToUid($uid, $message);// 向任意群组的网站页面发送数据
Gateway::sendToGroup($group, $message);
Nach dem Login kopieren

注意

以上仅是mvc框架与GatewayWorker官方推荐的结合方式,并不是强制使用此方式,开发者可以自由变化选择结合方式以适应自己的业务需求。


当然也可以采用客户端与GatewayWorker直接双向通讯的方式完成业务通讯。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

Yii1.1框架关于日志配置的使用

用laravel dingo api插件库创建api的方法

Das obige ist der detaillierte Inhalt vonEinführung in die Kombination von GatewayWorker und ThinkPHP und anderen Frameworks. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage