首頁 >後端開發 >php教程 >如何使用laravel-echo-server 建構一個事件廣播平台

如何使用laravel-echo-server 建構一個事件廣播平台

不言
不言原創
2018-07-27 10:50:014528瀏覽

這篇文章要跟大家介紹的文章內容是關於使用laravel-echo-server 搭建事件廣播平台,有很好的參考價值,希望可以幫助到有需要的朋友。

此文記錄一下先前專案中遇到的laravel後台廣播訊息到vue前台的實作過程。 Laravel 並未內建一個Socket.IO 伺服器實現,不過,這裡有一個第三方實現的Socket.IO 驅動:laravel-echo-server,相當於一個中間件;技術要點:laravel laravel-echo-server vue/laravel- echo

整體架構

如何使用laravel-echo-server 建構一個事件廣播平台

#1. laravel-echo-server

#1. laravel-echo-server

詳細介紹請參考:https:/ /github.com/tlaverdure...

1.1 laravel-echo-server
伺服器直接搭建在laravel專案中:① 全域安裝laravel-echo-server: npm install laravel-echo-server -g
;
② 控制台進入laravel項目,執行指令:

laravel-echo-server init

如何使用laravel-echo-server 建構一個事件廣播平台


如何使用laravel-echo-server 建構一個事件廣播平台

##在laravel專案中會多出一個laravel-echo-server.json

文件,裡麵包含了所有的設定資訊;

③ 透過執行

laravel-echo-server start

命令列啟動服務

1.2 laravel-echo-server伺服器獨立部署

#我們發現,其實只要有一個laravel-echo-server.json檔案就能啟動服務,那麼顯然可以將服務獨立出laravel專案部署(覺得沒必要可以不用這麼折騰)。 使用Http的方式推送訊息至laravel-echo-server伺服器,格式如下:

POST http://app.dev:6001/apps/your-appId/events?auth_key=you-key'
用postman測試:

################################################################################### ########測試成功,###laravel-echo-server###伺服器搭建成功######2. laravel後台######定義###BroadcastHttpPush.php## #作為介面###
<?php namespace App\HelpTrait;

use GuzzleHttp\Client;

trait BroadcastHttpPush
{
    public function push($data)
    {
        $baseUrl = env(&#39;WEBSOCKET_BASEURL&#39;, &#39;http://localhost:6001/&#39;);
        $appId = env(&#39;WEBSOCKET_APPID&#39;, &#39;3ccfbd93b5e2906a&#39;);
        $key = env(&#39;WEBSOCKET_KEY&#39;, &#39;6509c546c053d59057a61e46ae9a7898&#39;);
        $httpUrl = $baseUrl . &#39;apps/&#39; . $appId . &#39;/events?auth_key=&#39; . $key;
      
        $client = new Client([
            &#39;base_uri&#39; => $httpUrl,
            'timeout' => 2.0,
        ]);
        $response = $client->post($httpUrl, [
            'json' => $data
        ]);
        $code = $response->getStatusCode();
    }
}
###使用:###
<?php namespace App\Controllers;

use App\HelpTrait\BroadcastHttpPush;

class SendMessage
{
    use BroadcastHttpPush;
    
    public function index()
    {
        $broadcastChannel = array(
            "channel" => "private-Message",   // 通道名,`private-`表示私有
            "name" => "sayHello",    // 事件名
            "data" => array(
                "status" => 200, 
                "message" => "hello world!"
            )
        );
        $this->push($broadcastChannel);
    }
}
###3. vue前端#######定義###UserActionNotification.vue######
<template>
  <p>
    
  </p>
</template>

<script>
import Echo from &#39;laravel-echo&#39;
import io from &#39;socket.io-client&#39;
export default {
  mounted() {
    window.io = io
    window.Echo = new Echo({
      broadcaster: &#39;socket.io&#39;,
      host: &#39;http://localhost:6001&#39;,
    })
    window.Echo.private(&#39;Message&#39;).listen(&#39;.sayHello&#39;, (res) => {
       if (res.status === 200) {
         console.log(res.message)
       } else {
         console.log(&#39;something wrong!&#39;)
       }
    })
  }
}
</script>

<style></style>
#######註:###事件###sayHello###前面要加###.###, 不然需要帶上事件的網域空間;###### 相關推薦:######### Laravel如何操作資料庫? Laravel資料庫操作的三種方式(程式碼)############Laravel 5.5如何建立回應?建立回應的介紹(程式碼)######

以上是如何使用laravel-echo-server 建構一個事件廣播平台的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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