定制 khairy/laravel-sse-stream 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

khairy/laravel-sse-stream

最新稳定版本:v2.0

Composer 安装命令:

composer require khairy/laravel-sse-stream

包简介

Laravel package to provide Server Sent Events functionality for your app.

README 文档

README

![Latest Version on Packagist][ico-version] ![Total Downloads][ico-downloads]

Laravel SSE

Laravel package to provide Server Sent Events functionality for your app. You can use this package to show instant notifications to your users without them having to refresh their pages.

Requirements

  • PHP >= 8
  • Laravel 11 s

Installation

Via Composer

$ composer require khairy/laravel-sse-stream

For Laravel < 5.5:

Add Service Provider to config/app.php in providers section

Khairy\LaravelSSEStream\SSEServiceProvider::class,

Add Facade to config/app.php in aliases section

'SSE' => Khairy\LaravelSSEStream\Facades\SSEFacade::class,

Publish package's config, migration and view files by running below command:

php artisan vendor:publish --provider="Khairy\LaravelSSEStream\SSEServiceProvider"

Run php artisan migrate to create sselogs table.

Setup SSE

Setup config options in config/sse.php file and then add this in your view/layout file:

@include('sse::view')

Usage

Syntax:

/**
 * @param string $message : notification message
 * @param string $type : alert, success, error, warning, info
 * @param string $event : Type of event such as "EmailSent", "UserLoggedIn", etc
 */
SSEFacade::notify($message, $type = 'info', $event = 'message')

To show popup notifications on the screen, in your controllers/event classes, you can do:

use Khairy\LaravelSSEStream\Facades\SSEFacade;

public function myMethod()
{
    SSEFacade::notify('hello world....');
    
    // or via helper
    sse_notify('hi there');
}

Customizing Notification Library

By default, package uses noty for showing notifications. You can customize this by modifying code in resources/views/vendor/sse/view.blade.php file.

Customizing SSE Events

By default, pacakge uses message event type for streaming response:

SSEFacade::notify($message, $type = 'notification', $event = 'message')

Notice $event = 'message'. You can customize this, let's say you want to use login as SSE event type:

use Khairy\LaravelSSEStream\Facades\SSEFacade;

public function myMethod()
{
    SSEFacade::notify('hello world....', 'notification', 'login');
    
    // or via helper
    sse_notify('hi there', 'notification', 'login');
}

Then you need to handle this in your view yourself like this:

javascript

<script>
var es = new EventSource("{{route('__sse_stream__')}}");

es.addEventListener("UserLoggedIn", function (e) {
    var data = JSON.parse(e.data);
    alert(data.message);
}, false);

</script>

vuejs

<template>
  <div>
    <h1>Server-Sent Events in Vue.js</h1>
    <ul>
      <li v-for="message in messages" :key="message.id">{{ message.data }}</li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      eventSource: null, // To hold the EventSource instance
      messages: [] // To hold the received messages
    };
  },
  mounted() {
    this.startSSE();
  },
  beforeDestroy() {
    this.stopSSE();
  },
  methods: {
    startSSE() {
      this.eventSource = new EventSource('/sse/sse_stream');

      this.eventSource.onmessage = (event) => {
        const data = JSON.parse(event.data);
        this.messages.push(data);
      };

      this.eventSource.addEventListener('reconnect', (event) => {
        console.log('Reconnecting SSE...');
        this.stopSSE();
        setTimeout(this.startSSE, 1000); // Reconnect after 1 second
      });

      this.eventSource.onerror = (event) => {
        if (this.eventSource.readyState === EventSource.CLOSED) {
          console.error('SSE connection was closed.');
        } else {
          console.error('SSE encountered an error:', event);
        }
      };
    },
    stopSSE() {
      if (this.eventSource) {
        this.eventSource.close();
        this.eventSource = null;
      }
    }
  }
};
</script>

<style>
/* Add any necessary styles here */
</style>

Credits

License

Please see the license file for more information.

"# laravel-sse-stream"

统计信息

  • 总下载量: 151
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 6
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 5
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-07-23

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固