batformat / phpcent-broadcaster
适用于laravel的Centrifuge广播器 >= 5.3,支持Centrifuge v2
1.1
2019-06-17 11:07 UTC
Requires
- php: >=5.6.4
- illuminate/broadcasting: ^5.3
- predis/predis: ^1.1
Requires (Dev)
- orchestra/testbench: ^3.3
- phpunit/phpunit: ^5.7|^6.1
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)。请参阅 许可证文件 获取更多信息。