batformat/phpcent-broadcaster

适用于laravel的Centrifuge广播器 >= 5.3,支持Centrifuge v2

1.1 2019-06-17 11:07 UTC

This package is auto-updated.

Last update: 2024-09-26 05:39:52 UTC


README

简介

laracomponents/centrifuge-broadcaster 启发

适用于laravel的Centrifuge广播器 >= 5.3

要求

  • PHP 5.6.4+ 或更高版本
  • Laravel 5.3 或更高版本
  • Centrifugo服务器 2.0 或更高版本(见 此处
如果您使用Centrifugo服务器 1.6,应使用 LaraComponents/centrifuge-broadcaster

安装

使用composer安装此包

composer require batFormat/phpcent-broadcaster

打开您的config/app.php,并将以下内容添加到providers数组中

'providers' => [
    // ...
    TheArdent\Centrifuge\CentrifugeServiceProvider::class,

    // And uncomment BroadcastServiceProvider
    App\Providers\BroadcastServiceProvider::class,
],

打开您的config/broadcasting.php,并将以下内容添加到其中

'connections' => [
    'centrifuge' => [
        'driver'           => 'centrifuge',
        'api_key'          => env('CENTRIFUGE_API_KEY'), // you api key
        'secret'           => env('CENTRIFUGE_SECRET'), // you secret key
        'url'              => env('CENTRIFUGE_URL', 'https://:8000'), // centrifuge api url
        'redis_api'        => env('CENTRIFUGE_REDIS_API', false), // enable or disable Redis API
        'redis_connection' => env('CENTRIFUGE_REDIS_CONNECTION', 'default'), // name of redis connection
        'redis_prefix'     => env('CENTRIFUGE_REDIS_PREFIX', 'centrifugo'), // prefix name for queue in Redis
        'redis_num_shards' => env('CENTRIFUGE_REDIS_NUM_SHARDS', 0), // number of shards for redis API queue
        'verify'           => env('CENTRIFUGE_VERIFY', false), // Verify host ssl if centrifuge uses this
        'ssl_key'          => env('CENTRIFUGE_SSL_KEY', null), // Self-Signed SSl Key for Host (require verify=true)
    ],
    // ...
],

对于redis配置,在config/database.php中添加一个新的连接

'redis' => [
    'centrifuge' => [
        'host'     => env('REDIS_HOST', '127.0.0.1'),,
        'password' => env('REDIS_PASSWORD', null),
        'port'     => env('REDIS_PORT', 6379),
        'database' => 0,
    ],
    // ...
],

您还可以将配置添加到您的.env文件中

CENTRIFUGE_API_KEY=very-long-api-key
CENTRIFUGE_SECRET=very-long-secret-key
CENTRIFUGE_URL=https://:8000
CENTRIFUGE_REDIS_API=false
CENTRIFUGE_REDIS_CONNECTION=centrifuge
CENTRIFUGE_REDIS_PREFIX=centrifugo
CENTRIFUGE_REDIS_NUM_SHARDS=0
CENTRIFUGE_SSL_KEY=/etc/ssl/some.pem
CENTRIFUGE_VERIFY=false

不要忘记安装广播驱动器

BROADCAST_DRIVER=centrifuge

基本用法

要配置Centrifugo服务器,请阅读 官方文档

有关广播事件的详细信息,请参阅 laravel官方文档

客户端使用简单示例

<?php

namespace App\Http\Controllers;

use TheArdent\Centrifuge\Centrifuge;

class ExampleController extends Controller
{
    public function home(Centrifuge $centrifuge)
    {
        // Send message into channel:
        $centrifuge->publish('channel-name', [
            'key' => 'value'
        ]);

        // Generate token without expire:
        $token = $centrifuge->generateToken('user id');

        // Connection token that will be valid for 5 minutes:
        $token = $centrifuge->generateConnectionToken('user id', time() + 5*60);

        //It's also possible to generate private channel subscription token:
        $token = $centrifuge->generatePrivateChannelToken('user id', 'channel');
    }
}

可用方法

与LaraComponents/centrifuge-broadcaster的区别

许可证

MIT许可证(MIT)。请参阅 许可证文件 获取更多信息。