Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana Penyiaran Laravel Berfungsi
Hari ini, kita akan meneroka konsep penyiaran dalam kerangka web Laravel. Ia membolehkan anda menghantar pemberitahuan ke sisi klien apabila sesuatu berlaku di sisi pelayan. Dalam artikel ini, kami akan menggunakan perpustakaan pusher pihak ketiga untuk menghantar pemberitahuan ke sisi klien. Sekarang, apabila Pengguna A menghantar mesej kepada Pengguna B, anda ingin memberitahu Pengguna B dalam masa nyata. Anda boleh memaparkan popup atau kotak amaran yang memberitahu pengguna B tentang mesej baru!
Ini adalah kes penggunaan yang sempurna untuk berjalan melalui konsep penyiaran di Laravel, dan itulah yang akan kami laksanakan dalam artikel ini. Mari kita fahami aliran asas soket sebelum kita menyelam lebih mendalam ke dalam pelaksanaan sebenar. Kami lebih suka yang terakhir dalam artikel ini. Untuk. Anda akan mendapat hang itu semasa kami bergerak melalui artikel ini. Log
penyesuai. Sudah tentu, jika anda menggunakan penyesuaipenolak sebagai pemacu siaran lalai kami. Oleh itu, mari kita ubah fail migrasi
pangkalan data/migrasi/xxxx_xx_xx_xxxxxx_create_messages_table.php<?php<br><br>return [<br><br> /*<br> |--------------------------------------------------------------------------<br> | Default Broadcaster<br> |--------------------------------------------------------------------------<br> |<br> | This option controls the default broadcaster that will be used by the<br> | framework when an event needs to be broadcast. You may set this to<br> | any of the connections defined in the "connections" array below.<br> |<br> | Supported: "pusher", "redis", "log", "null"<br> |<br> */<br><br> 'default' => env('BROADCAST_DRIVER', 'null'),<br><br> /*<br> |--------------------------------------------------------------------------<br> | Broadcast Connections<br> |--------------------------------------------------------------------------<br> |<br> | Here you may define all of the broadcast connections that will be used<br> | to broadcast events to other systems or over websockets. Samples of<br> | each available type of connection are provided inside this array.<br> |<br> */<br><br> 'connections' => [<br><br> 'pusher' => [<br> 'driver' => 'pusher',<br> 'key' => env('PUSHER_APP_KEY'),<br> 'secret' => env('PUSHER_APP_SECRET'),<br> 'app_id' => env('PUSHER_APP_ID'),<br> 'options' => [<br> 'cluster' => env('PUSHER_APP_CLUSTER'),<br> 'useTLS' => true,<br> ],<br> ],<br><br> 'redis' => [<br> 'driver' => 'redis',<br> 'connection' => 'default',<br> ],<br><br> 'log' => [<br> 'driver' => 'log',<br> ],<br><br> 'null' => [<br> 'driver' => 'null',<br> ],<br><br> ],<br><br>];<br>
Setiap kali anda ingin menaikkan acara tersuai di Laravel, anda harus membuat kelas untuk acara itu. Berdasarkan jenis peristiwa, Laravel bertindak balas dengan sewajarnya dan mengambil tindakan yang diperlukan. Sebaliknya, jika acara itu adalah jenis penyiaran, Laravel menghantar acara itu ke pelayan web-socket yang dikonfigurasi dalam fail config/breadcasting.php
. lain-lain maklumat berkaitan pusher yang diperlukan. Seperti yang telah dibincangkan sebelum ini, pelanggan mesti mengesahkan dirinya sebelum melanggan saluran persendirian. Oleh itu, objek melakukan pengesahan yang diperlukan dengan menghantar XHR di latar belakang dengan parameter yang diperlukan. Akhirnya, Laravel cuba mencari user. {User_id} <strong> route, dan ia sepadan dengan laluan yang telah kami tentukan dalam </strong> laluan/channels.php
Jadi persediaan untuk menerima acara dari pelayan web-sockets. Seterusnya, kami akan melalui kaedah
dalam fail pengawal yang menimbulkan acara penyiaran. Oleh itu, kami telah cuba meniru tingkah laku itu dalam kaedah . Oleh kerana NewMessAgenotification
hendaklahbroadcastnow <ship> type, Laravel memuatkan konfigurasi siaran lalai dari fail <p> config/breadcasting.php <code>private
. Akhirnya, ia menyiarkan acara NewMessAgenotification <code>user.{USER_ID}
ke pelayan web-socket yang dikonfigurasikan pada pengguna . {User_id} <code>Echo
Dalam kes kami, acara itu akan disiarkan ke pelayan web-socket Pusher pada saluran user.{USER_ID}
. Sekiranya ID pengguna penerima adalah 1
, acara itu akan disiarkan melalui saluran user.1
. Kami telah membina setakat ini.
Buka URL https: // your-laravel-site-domain/message/index dalam penyemak imbas anda. Jika anda belum log masuk, anda akan diarahkan ke skrin log masuk. Sebaik sahaja anda log masuk, anda harus melihat pandangan siaran yang kami tentukan sebelum ini -tidak ada yang mewah lagi. Memandangkan kami telah mengaktifkan tetapan
yang disediakan oleh perpustakaan klien Pusher, ia log segala -galanya dalam konsol penyemak imbas untuk tujuan debugging. Mari kita lihat apa yang sedang dilog masuk ke konsol apabila anda mengakses http: // halaman-laravel-site-domain/mesej/indeks. Sudah tentu, anda boleh mempunyai nama saluran yang berbeza dalam kes anda berdasarkan ID pengguna yang anda log masuk. Sekarang, mari kita buka halaman ini ketika kita bergerak untuk menguji kaedahkonsol
, anda harus dapat melihat mesej yang dilog masuk. Mudah -mudahan, ia tidak terlalu banyak dalam satu perjalanan kerana saya telah cuba mempermudahkan perkara dengan pengetahuan saya yang terbaik.
Hari ini, kami melalui salah satu ciri -ciri yang dibincangkan dari Laravel -castcasting. Ia membolehkan anda menghantar pemberitahuan masa nyata menggunakan soket web. Sepanjang artikel ini, kami membina contoh dunia nyata yang menunjukkan konsep yang disebutkan di atas.
Atas ialah kandungan terperinci Bagaimana Penyiaran Laravel Berfungsi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!