laravel6中使用广播推送消息

使用laravel广播推送消息

项目是基于laravel6开发的一个论坛项目,里面有公告和私信功能,需求要求做到实时推送


方案
  1. 使用php socket 搭建
  2. 使用laravel自带的广播

php socket在laravel中使用搭建起来比较麻烦,而且要封装函数,对于一个小功能来说成本太高,决定使用laravel自带的广播功能来实现

laravel广播驱动类型
  1. pusher
    1. 官方默认的,收费
  2. redis
    1. 可搭配socket.io使用
最终方案

使用laravel广播基于redis驱动搭配socket.io实现该功能

因为要使用node.js安装相关包,要先安装node.js

  1. 打开laravel默认关闭的广播服务 config\app.php

  1. 注释掉redis配置里的前缀设置(laravel中默认有前缀) config'database.php

  1. 修改.env文件中的修改广播驱动为redis

4.安装laravel中redis扩展,这里以predis为列

composer require predis/predis

安装完成后设置.env中的REDIS_CLIENT设置为predis
如果不想设置,可以调整config\database.php中的clinet默认为predis

  1. 安装依赖
// 更新依赖

npm install

//安装负责处理socket的node.js包

npm install -g laravel-echo-server

//安装前端事务处理包

npm install --save socket.io-client
npm install --save laravel-echo

//运行socket服务

laravel-echo-server init

//启动

laravel-echo-server start 

运行成功

  1. 查看npm安装包

  1. 创建一个event php artisan make:event TestEvent 代码如下
<?php

namespace App\Events;

use Illuminate\Broadcasting\Channel;
use Illuminate\Queue\SerializesModels;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;

class TestEvent implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    public $message;

    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct($test)
    {
        //
        $this->message = $test;
    }

    // 广播频道
    public function broadcastOn()
    {
        // return new PrivateChannel('channel-name');
        return new Channel('test_public_channel');
    }

    // 广播内容
    public function broadcastWith()
    {
        return [
            'data' => $this->message
        ];
    }

    // 广播事件名称,默认为 App\Events\TestEvent
    public function broadcastAs()
    {
        return 'TestEvent';
    }

    // 决定是否广播的条件
    public function broadcastWhen()
    {
        if ('test') {
            return true;
        }
    }
}


  1. 前端接收广播
//需要加入token 广播强制要求

<meta name="csrf-token" content="{{ csrf_token() }}">

//引入socket.io.js

<script src="//{{ Request::getHost() }}:6001/socket.io/socket.io.js"></script>


<script type="module">
//在js中引入echo.js

 import Echo from '/static/echo.js';
 
 //初始化echo
 
 window.Echo = new Echo({
        broadcaster: 'socket.io',
        host: 'http://' + window.location.hostname + ':6001'
    });
 
 //公共频道
 
  window.Echo.channel('test_public_channel')
        .listen('.TestEvent', (e) => { // 注意,如果在laravel事件中用broadcastAs方法设置了广播事件名称,则这里监听的事件名称前要加"."。
            console.log(e);
        });
        
 </script>

注:如果找不到echo.js文件,在项目下node_modules\laravel-echo\dist找到echo.js复制到对应的目录下即可

  1. 调用方法
    broadcast(new TestEvent('你的文章被点赞了'));

前端收到对应消息

  1. 私有频道

推送消息是时候用到了私有频道,操作如下:

  1. 创建一个私有频道的event php artisan make:event PrivateEvent ,代码如下:
<?php

namespace App\Events;

use Illuminate\Broadcasting\Channel;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;

class PrivateEvent implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    protected $user_id;
    protected $info;
    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct($user_id,$info)
    {
        $this->user_id =$user_id;
        $this->info = $info;

    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    public function broadcastOn()
    {
        return new PrivateChannel('user-'.$this->user_id);
    }


    public function broadcastAs()
    {
        return 'PrivateEvent';

    }

    public function broadcastWith()
    {
        $data = ['id'=>$this->user_id,'type'=>$this->info['type'],'message'=>$this->info['message']];
        return ['data'=>$data];
    }
}

2.在路由channel.php中设置如下内容

//这里的意思只有前端用户才有权限

Broadcast::channel('user-.{user_id}', function ($user_id, $data) {
    return true;
},['guards'=>'web']);

3.前端代码

//需要加入token 广播强制要求

<meta name="csrf-token" content="{{ csrf_token() }}">

//引入socket.io.js

<script src="//{{ Request::getHost() }}:6001/socket.io/socket.io.js"></script>


<script type="module">
//在js中引入echo.js

 import Echo from '/static/echo.js';
 
 //初始化echo
 
 window.Echo = new Echo({
        broadcaster: 'socket.io',
        host: 'http://' + window.location.hostname + ':6001'
    });
 
  //调用私有频道监控
  
    window.Echo.private("user-{{auth()->id()}}")
        .listen('.PrivateEvent', (e) => {// 注意,如果在laravel事件中用broadcastAs方法设置了广播事件名称,则这里监听的事件名称前要加"."。
            console.log(e);
        })
        
 </script>


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Laravel是一款流行的PHP开发框架,它提供了强大的功能和工具以简化Web应用程序的开发过程。MQTT是一种轻量级的消息传输协议,通常用于物联网设备之间的通信和数据传输。 在Laravel使用MQTT推送可以实现实时的消息传递和通知功能。首先,我们需要安装和配置MQTT客户端库,例如phpMQTT。然后,通过引入客户端库并创建MQTT客户端对象,我们可以连接到MQTT服务器。 在Laravel,我们可以使用事件和监听器的机制来触发和处理MQTT推送。首先,我们需要定义一个自定义的事件,例如MQTTPushEvent,并在该事件包含要传递的消息和主题。 然后,我们可以创建一个事件监听器来处理MQTT推送事件。在监听器,我们可以获取事件的消息和主题,并使用之前创建的MQTT客户端对象将消息推送到指定的主题上。 最后,我们需要在Laravel应用程序配置和注册事件和监听器,以便在需要的时候触发和处理MQTT推送事件。 总结起来,使用Laravel实现MQTT推送可以通过安装和配置MQTT客户端库、定义事件和监听器、在监听器处理MQTT推送,以及在应用程序注册事件和监听器来完成。这样就可以在Laravel应用程序实现实时的消息传递和通知功能。 ### 回答2: Laravel是一款流行的PHP开发框架,它为我们提供了一种简洁且高效的方式来构建Web应用程序。而MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,它被广泛用于物联网领域。 在Laravel实现MQTT推送可以帮助我们构建实时通信功能,使我们的应用程序能够传输和接收实时数据。下面是一个示例,展示了如何在Laravel实现MQTT推送。 首先,我们需要安装一个Laravel的MQTT扩展包,比如“php-mqtt/php-mqtt”。我们可以通过Composer进行安装:composer require php-mqtt/php-mqtt 安装好扩展包后,我们需要在Laravel的配置文件config/mqtt.php进行MQTT连接的相关配置,包括服务器地址、端口、用户名、密码等。 接下来,我们可以在Laravel的控制器使用MQTT客户端进行消息发布。通过如下代码可以实现消息的发布: ```php use PhpMqtt\Client\Facades\MQTT; // 创建连接 MQTT::connect(); // 发布消息 MQTT::publish('topic', 'message'); // 关闭连接 MQTT::disconnect(); ``` 在上述代码,我们使用MQTT::connect()来建立与MQTT服务器的连接,然后使用MQTT::publish()来发布消息。通过指定话题(topic)和消息内容(message),我们就可以将消息发送给订阅该话题的客户端。最后,我们使用MQTT::disconnect()来关闭连接。 除了消息发布,我们还可以使用MQTT作为消息订阅者来接收实时数据。在Laravel,我们可以通过如下代码进行消息订阅: ```php use PhpMqtt\Client\Facades\MQTT; use PhpMqtt\Client\MqttClient; // 创建连接 MQTT::connect(); // 订阅主题 MQTT::subscribe(['topic1', 'topic2'], function (string $topic, string $message, MqttClient $client) { // 处理接收到的消息 // ... }); // 监听消息 MQTT::loop(true); // 关闭连接 MQTT::disconnect(); ``` 在上述代码,我们使用MQTT::subscribe()来订阅多个话题,并通过匿名函数来处理接收到的消息。在匿名函数,我们可以根据实际需求对接收到的消息进行处理。最后,我们使用MQTT::loop(true)来监听消息,直到我们关闭连接。关闭连接的步骤和之前的发布示例相同。 以上就是使用Laravel实现MQTT推送的简要说明。当然,具体的实现方式会因项目需求和开发环境的不同而有所差异,但总体思路是一致的。希望对你有所帮助! ### 回答3: Laravel是一种流行的PHP框架,而MQTT是物联网设备通信协议。Laravel可以使用MQTT来实现消息推送功能。 首先,在Laravel,我们需要使用一个MQTT客户端库来与MQTT代理进行通信。有一些开源的MQTT客户端库可供选择,例如php-mqtt/php-mqtt或eclipse/paho.mqtt.php。我们可以使用Composer来安装这些库。 然后,我们需要配置Laravel的环境文件,将MQTT代理的连接信息添加到配置文件。这样,我们就可以在代码使用这些配置信息来连接MQTT代理。 接下来,我们可以使用Laravel的事件系统来定义并触发一个自定义事件。当某个事件被触发时,我们可以调用MQTT客户端库来将消息发布到MQTT代理。这样,其他订阅了相同主题的设备或客户端就可以接收到这条消息。 在订阅方面,我们可以使用MQTT客户端库来订阅一个特定的主题。当有新的消息发布到这个主题时,我们可以在Laravel编写事件监听器来处理这些消息。 总之,使用Laravel实现MQTT推送功能的基本步骤是:安装MQTT客户端库、配置环境文件、定义并触发自定义事件、使用事件监听器处理消息。这样,我们就可以在Laravel应用程序实现MQTT推送功能。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值