Home >Backend Development >PHP Tutorial >How to use laravel-echo-server to build an event broadcast platform

How to use laravel-echo-server to build an event broadcast platform

不言
不言Original
2018-07-27 10:50:014568browse

This article introduces you to the article about using laravel-echo-server to build an event broadcast platform. It has a good reference value and I hope it can help friends in need.

This article records the implementation process of laravel background broadcasting messages to the vue frontend encountered in previous projects. Laravel does not have a built-in Socket.IO server implementation, but there is a third-party implemented Socket.IO driver: laravel-echo-server, which is equivalent to a middleware; technical points: laravel laravel-echo-server vue/laravel- echo

Overall architecture

How to use laravel-echo-server to build an event broadcast platform

1. laravel-echo-server

For detailed introduction, please see: https:/ /github.com/tlaverdure...

1.1 laravel-echo-serverThe server is built directly in the laravel project:

① Install laravel-echo-server globally: npm install laravel-echo-server -g;
② Enter the laravel project in the console and run the command: laravel-echo-server init

How to use laravel-echo-server to build an event broadcast platform
There will be an extra laravel-echo-server.json file in the laravel project, which contains all configuration information;
③ Start the service by running laravel-echo-server start command line

1.2 laravel-echo-serverServer independent deployment

We found that, In fact, as long as there is a laravel-echo-server.json file to start the service, then obviously the service can be deployed independently from the laravel project (you don't have to worry about it if it's not necessary).
Use Http to push messages to the laravel-echo-server server. The format is as follows:

POST http://app.dev:6001/apps/your-appId/events?auth_key=you-key'

Test with postman:

How to use laravel-echo-server to build an event broadcast platform

The test was successful, laravel-echo-serverthe server was built successfully

2. laravel background

DefinitionBroadcastHttpPush.phpAs an interface

<?php namespace App\HelpTrait;

use GuzzleHttp\Client;

trait BroadcastHttpPush
{
    public function push($data)
    {
        $baseUrl = env(&#39;WEBSOCKET_BASEURL&#39;, &#39;http://localhost:6001/&#39;);
        $appId = env(&#39;WEBSOCKET_APPID&#39;, &#39;3ccfbd93b5e2906a&#39;);
        $key = env(&#39;WEBSOCKET_KEY&#39;, &#39;6509c546c053d59057a61e46ae9a7898&#39;);
        $httpUrl = $baseUrl . &#39;apps/&#39; . $appId . &#39;/events?auth_key=&#39; . $key;
      
        $client = new Client([
            &#39;base_uri&#39; => $httpUrl,
            'timeout' => 2.0,
        ]);
        $response = $client->post($httpUrl, [
            'json' => $data
        ]);
        $code = $response->getStatusCode();
    }
}

Use:

<?php namespace App\Controllers;

use App\HelpTrait\BroadcastHttpPush;

class SendMessage
{
    use BroadcastHttpPush;
    
    public function index()
    {
        $broadcastChannel = array(
            "channel" => "private-Message",   // 通道名,`private-`表示私有
            "name" => "sayHello",    // 事件名
            "data" => array(
                "status" => 200, 
                "message" => "hello world!"
            )
        );
        $this->push($broadcastChannel);
    }
}

3. vue front-end

DefinitionUserActionNotification.vue

<template>
  <p>
    
  </p>
</template>

<script>
import Echo from &#39;laravel-echo&#39;
import io from &#39;socket.io-client&#39;
export default {
  mounted() {
    window.io = io
    window.Echo = new Echo({
      broadcaster: &#39;socket.io&#39;,
      host: &#39;http://localhost:6001&#39;,
    })
    window.Echo.private(&#39;Message&#39;).listen(&#39;.sayHello&#39;, (res) => {
       if (res.status === 200) {
         console.log(res.message)
       } else {
         console.log(&#39;something wrong!&#39;)
       }
    })
  }
}
</script>

<style></style>

Note : EventsayHello must be preceded by ., otherwise you need to bring the domain name space of the event;

Related recommendations:

How does Laravel operate the database? Three ways of Laravel database operation (code)

How to create a response in Laravel 5.5? Introduction to creating responses (code)

The above is the detailed content of How to use laravel-echo-server to build an event broadcast platform. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn