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

Laravel學(xué)習(xí)教程之廣播模塊詳解

 更新時間:2017年08月22日 10:53:28   作者:GreenLightt  
這篇文章主要給大家介紹了關(guān)于Laravel學(xué)習(xí)教程之廣播模塊的相關(guān)資料,廣播是指發(fā)送方發(fā)送一條消息,訂閱頻道的各個接收方都能及時收到消息,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

本文主要給大家介紹了關(guān)于Laravel廣播模塊的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細的介紹:

注意:本文是基于Laravel 5.4版本的路由模塊代碼進行分析書寫;

簡介

廣播是指發(fā)送方發(fā)送一條消息,訂閱頻道的各個接收方都能及時收到消息;比如 A同學(xué)寫了一篇文章,這時候 B同學(xué)在文章底下評論了,A同學(xué)在頁面上是不用刷新就能收到提示有文章被評論了,這個本質(zhì)上就是A同學(xué)收到了廣播消息,這個廣播消息是由B同學(xué)評論這個動作觸發(fā)了發(fā)送廣播消息;

在整個廣播行為中,有一個重要的概念叫頻道channel,頻道的類型有

  • 公共頻道public
  • 私有頻道private
  • 存在頻道presence

移動端訂閱了公共頻道public,會直接提示成功;私有頻道private和存在頻道presence在進行訂閱的過程中,會向服務(wù)器端發(fā)送權(quán)限驗證,看是不是有權(quán)限可以訂閱該頻道;私有頻道private和存在頻道presence的區(qū)別在于,私有頻道private能夠接收其他成員發(fā)送的消息,而存在頻道presence除此之外,還能夠在用戶的加入與離開時接收信息;

廣播適合以下場景:

  • 通知(Notification) 或 信號(Signal)
  • 通知是最簡單的示例,也最經(jīng)常用到。信號也可看作是通知的一種展現(xiàn)形式,只不過信號沒有UI而已。
  • Activity Streams
  • Activity Streams(feeds)是社交網(wǎng)絡(luò)的核心。如微信朋友圈的點贊和評論,A可以實時看到B的點贊,B可以實時看到A的評論。
  • 聊天
  • 聊天信息的實時顯示

模塊組成


Demo

日志驅(qū)動

配置

.env文件修改或添加一行:BROADCAST_DRIVER=log

廣播

直接調(diào)用

 $manager = app(Illuminate\Broadcasting\BroadcastManager::class);
 $driver = $manager->connection();
 // 第一個參數(shù)是頻道名,第二個參數(shù)是事件名,第三個參數(shù)是廣播內(nèi)容
 $driver->broadcast(['channel_1', 'channel_2'], 'login', ['message' => 'hello world']);

因為是日志驅(qū)動,所以廣播內(nèi)容會寫到框架配置的日志文件中,輸出消息如下所示

[2017-08-18 20:45:49] local.INFO: Broadcasting [login] on channels [channel_1, channel_2] with payload:
{
 "message": "hello world"
} 

監(jiān)聽事件廣播

這種調(diào)用方式,是當(dāng)實現(xiàn)ShouldBroadcast接口的事件被觸發(fā)時,則會進行廣播操作;(同時,還有一個接口叫ShouldBroadcastNow,與ShouldBroadcast接口的不同在于,將實現(xiàn)ShouldBroadcastNow接口的事件放入隊列中時,會被放入叫sync的隊列中)

舉個例子,

第一步,Illuminate\Auth\Events\Login事件是用戶登錄成功后會觸發(fā)的事件,略作改動,讓其實現(xiàn)廣播功能;

class Login implements ShouldBroadcast {
 ......
 
 // 定義事件被觸發(fā)時,廣播頻道;此處定義名為 first-channel 的私有頻道
 public function broadcastOn() {
  return [
   new PrivateChannel('first-channel'),
  ];
 }
 
 // 自定義廣播名稱;如果方法未定義,默認(rèn)以類名為事件名,此處的默認(rèn)值是 Illuminate\Auth\Events\Login
 public function broadcastAs() {
  return 'login';
 }
}

第二步,注冊事件監(jiān)聽;在app/Providers/EventServiceProvider.php中修改:

protected $listen = [
 ......
 'Illuminate\Auth\Events\Login' => [
  'App\Listeners\UserLogin',
 ],
];

文件app/Listeners/UserLogin.php粗糙地實現(xiàn)了一下:

class UserLogin {
 public function __construct() {}
 
 public function handle(Login $event){
  \Log::info('Do UserLogin Listener: I was Login');
 }
}

第三步,觸發(fā)事件,發(fā)送廣播;有好幾種觸發(fā)廣播方式:

直接事件觸發(fā)

event(new Illuminate\Auth\Events\Login($user, true));

幫助函數(shù)broadcast,間接觸發(fā)事件

broadcast(new Illuminate\Auth\Events\Login($user, true));

廣播管理類,間接觸發(fā)事件,直接廣播

$manager = app(Illuminate\Broadcasting\BroadcastManager::class);
$manager->event(new Illuminate\Auth\Events\Login($user, true));

廣播管理類,間接觸發(fā)事件,放入隊列

$manager = app(Illuminate\Broadcasting\BroadcastManager::class);
$manager->queue(new Illuminate\Auth\Events\Login($user, true));

Pusher驅(qū)動

Pusher是一個第三方服務(wù),服務(wù)器發(fā)送廣播時,會向Pusher發(fā)送請求,再通過Pusher與瀏覽器或移動端保持的長連接進行數(shù)據(jù)交互;

配置

通過Pusher官網(wǎng)注冊用戶信息,獲取屬于自已的一套密鑰信息,修改.env的配置文件;

BROADCAST_DRIVER=pusher
PUSHER_APP_ID=xxxxxxxxxxxxxxxxxxxxxx
PUSHER_APP_KEY=xxxxxxxxxxxxxxxxxxxxxx
PUSHER_APP_SECRET=xxxxxxxxxxxxxxxxxxxxxx

準(zhǔn)備工作

事件監(jiān)聽

后臺的事件監(jiān)聽還是采用"日志驅(qū)動"部分的登錄例子;

前端

前端頁面引入以下代碼:

<script src="https://js.pusher.com/4.1/pusher.min.js"></script>

<script>
// 打開 Pusher 的調(diào)試日志
Pusher.logToConsole = true;

// 定義 Pusher 變量
var pusher = new Pusher('PUSHER_APP_KEY的值', {
 cluster: 'ap1',
 encrypted: true
});

// 定義頻道,綁定事件
var channel = pusher.subscribe('private-first-channel');
channel.bind('login', function(data) {
 alert(data);
});
</script>

如果訂閱的是公共頻道,則不會向服務(wù)器端請求權(quán)限檢查;如果是私有頻道(頻道名是以private-開頭)或存在頻道(頻道名是以presence-開頭),則會發(fā)出權(quán)限檢查請求;對應(yīng)的后端需要定義私有頻道和存在頻道的權(quán)限;

頻道權(quán)限定義

頻道的權(quán)限定義是在routes/channels.php里;此處筆者為first-channel頻道定義權(quán)限回調(diào)函數(shù):

Broadcast::channel('first-channel', function ($user) {
  return (int) $user->id === 1;
});

有讀者會疑問,前端頁面訂閱的頻道不是private-first-channel嗎?怎么后端只定義first-channel頻道的權(quán)限呢?那是因為,后端定義的頻道假設(shè)是A,那么在Pusher及瀏覽器端或移動端傳遞的私有頻道名為private-A,存在頻道則會是presence-A;

廣播

直接廣播

$manager = app(Illuminate\Broadcasting\BroadcastManager::class);
$driver = $manager->connection();
// socket 參數(shù)是廣播私有頻道時排除的 socket, 每個瀏覽器端或者移動端在建立 websocket 時都會被分配一個 socket_id
$driver->broadcast(['private-first-channel'], 'login', ['user' => ['name' => 'hello'], 'socket' => '5395.4377611']);

間接廣播

參考“日志驅(qū)動”提及的間接廣播方式;

如果要發(fā)送排我廣播(也就是除了當(dāng)前請求的這個客戶端不收到廣播消息),則需要以下條件:

  • 事件使用Illuminate\Broadcasting\InteractsWithSockets trait;
  • 前端發(fā)送過來的請求頭部要攜帶X-Socket-ID信息;
  • 事件觸發(fā)執(zhí)行broadcast(new Illuminate\Auth\Events\Login($user, true))->toOthers();

Redis驅(qū)動

配置

.env文件修改或添加一行:BROADCAST_DRIVER=redis

廣播

原理是同樣在后端部署一個Socket.IO服務(wù)器,Laravel框架會發(fā)布消息到Socket.IO服務(wù)器上,由Socket.IO服務(wù)器同瀏覽器端或者移動端保持長連接;

這部分筆者尚未demo,網(wǎng)上入門資料還是挺多的,知道原理,這部分動作上手就容易多了;

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

附錄

同類型的文章可參考以下,加深了解:

相關(guān)文章

  • php過濾敏感詞的示例

    php過濾敏感詞的示例

    這篇文章主要介紹了php過濾敏感詞的示例,需要的朋友可以參考下
    2014-03-03
  • Laravel5.1 框架表單驗證操作實例詳解

    Laravel5.1 框架表單驗證操作實例詳解

    這篇文章主要介紹了Laravel5.1 框架表單驗證操作,結(jié)合實例形式詳細分析了laravel5.1框架表單驗證的具體實現(xiàn)步驟、實現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下
    2020-01-01
  • UCenter 批量添加用戶的php代碼

    UCenter 批量添加用戶的php代碼

    有時候我們需要批量添加用戶,只要把該php放進UCenter目錄下,執(zhí)行就可以了。
    2012-07-07
  • PHP分頁類集錦

    PHP分頁類集錦

    本文匯集了幾個比較好用的php分頁類,都是經(jīng)過廣大網(wǎng)友考驗的代碼了,小伙伴們可以直接拿來使用
    2014-11-11
  • PHP寫的資源下載防盜鏈類分享

    PHP寫的資源下載防盜鏈類分享

    這篇文章主要介紹了PHP寫的資源下載防盜鏈類分享,需要的朋友可以參考下
    2014-05-05
  • php unlink()函數(shù)使用教程

    php unlink()函數(shù)使用教程

    最近在寫個網(wǎng)站,需要上傳圖片,如果修改圖片,就圖片就沒有用了,會占用服務(wù)器的硬盤資源,所以想到用unlink函數(shù)刪除舊照片.下面腳本之家小編給大家?guī)砹藀hp unlink()函數(shù)使用教程,感興趣的朋友一起看看吧
    2018-07-07
  • Yii框架防止sql注入,xss攻擊與csrf攻擊的方法

    Yii框架防止sql注入,xss攻擊與csrf攻擊的方法

    這篇文章主要介紹了Yii框架防止sql注入,xss攻擊與csrf攻擊的方法,結(jié)合實例形式分析了Yii框架針對sql注入,xss攻擊與csrf攻擊的防范方法與相關(guān)函數(shù)調(diào)用注意事項,需要的朋友可以參考下
    2016-10-10
  • PHP實現(xiàn)獲取FLV文件的時間

    PHP實現(xiàn)獲取FLV文件的時間

    這篇文章主要介紹了PHP實現(xiàn)獲取FLV文件的時間,本文直接給出實現(xiàn)代碼和使用方法,需要的朋友可以參考下
    2015-02-02
  • Thinkphp搜索時首頁分頁和搜索頁保持條件分頁的方法

    Thinkphp搜索時首頁分頁和搜索頁保持條件分頁的方法

    這篇文章主要介紹了Thinkphp搜索時首頁分頁和搜索頁保持條件分頁的方法,以兩種不同的方式詳細分析了實現(xiàn)搜索時分頁情況下保持搜索條件的方法,是非常具有實用價值的技巧,需要的朋友可以參考下
    2014-12-12
  • PHP開發(fā)中csrf攻擊的簡單演示和防范

    PHP開發(fā)中csrf攻擊的簡單演示和防范

    CSRF的全名為Cross-site request forgery,它的中文名為 跨站請求偽造(偽造跨站請求【這樣讀順口一點】)CSRF是一種夾持用戶在已經(jīng)登陸的web應(yīng)用程序上執(zhí)行非本意的操作的攻擊方式。相比于XSS,CSRF是利用了系統(tǒng)對頁面瀏覽器的信任,XSS則利用了系統(tǒng)對用戶的信任。
    2017-05-05

最新評論