목차
搭建基础环境" >搭建基础环境
使用 Laravel Echo Server" >使用 Laravel Echo Server
总结" >总结
기본 환경 구축" >기본 환경 구축
Laravel Echo 서버 사용하기" >Laravel Echo 서버 사용하기
요약" >요약
PHP 프레임워크 Laravel Laravel 프레임워크에서 Echo를 사용하는 과정

Laravel 프레임워크에서 Echo를 사용하는 과정

Jul 31, 2018 pm 04:19 PM
laravel php

오늘 이 글에서는 laravel 프레임워크에서 echo를 사용하는 방법에 대해 설명하겠습니다. 이 글의 내용은 단계별로 16단계를 거쳐 진행됩니다. 도움이 필요한 사람들에게 도움이 되기를 바랍니다. 별로 할말은 없고 바로 본론으로 들어가겠습니다.

공식문서에서는 Pusherlaravel-echo-server(NodeJS를 사용하는 메소드) 사용을 권장하고 있습니다. Socket .IOWebSocket 서버를 구현했습니다). Pusher 或者 laravel-echo-server (是一个使用 NodeJS + Socket.IO 实现的 WebSocket 服务端)。

在国内,个人还是不推荐使用 Pusher,访问速度有所影响,而且其还是一个商业产品。

今天利用最简便的「16」步,走一遍代码集成 laradocklaravel-echo-server 来使用 Laravel Echo

搭建基础环境

// 1. new project
laravel new echolearning

// 2. 使用 laradock
git clone https://github.com/Laradock/laradock.git

// 3. 创建 .env
cp env-example .env

// 4. 创建 container
docker-compose up -d php-worker laravel-echo-server nginx redis
로그인 후 복사

Laravel 프레임워크에서 Echo를 사용하는 과정

// 5. 进入 workspace 容器
docker-compose exec --user=laradock workspace bash

// 6. 安装插件
// 6.1 推荐使用 laravel-china 维护的 composer 国内镜像
composer config -g repo.packagist composer https://packagist.laravel-china.org

// 6.2 并行下载插件
composer global require "hirak/prestissimo"

// 6.3 配置 yarn 国内镜像
yarn config set registry 'https://registry.npm.taobao.org'

// 注:以上可以在 laradock 中配置
// 6.4 执行安装
composer install

yarn install

// 7. 创建 .env 和 key
cp .env.example .env
php artisan key:generate
로그인 후 복사

好了,我们开始在浏览器输入:http://localhost,网站跑起来了

Laravel 프레임워크에서 Echo를 사용하는 과정

使用 Laravel Echo Server

因为 laradock 集成了「Laravel Echo Server」,所以我们很方便的使用到 Laravel Echo

// 8. 配置广播驱动和 redis 服务器
BROADCAST_DRIVER=redis
REDIS_HOST=redis

// 9. 安装 predis
composer require predis/predis
로그인 후 복사

准备好后端配置后,我们开始安装前端插件,毕竟 Laravel Echo  是前端工具。

// 10. 安装 socket.io-client laravel-echo
yarn add socket.io-client laravel-echo
로그인 후 복사

resources/assets/js/bootstrap.js 实例化 Echo

// 11. 实例化 Echo
import Echo from 'laravel-echo'

window.io = require('socket.io-client')

window.Echo = new Echo({
    broadcaster: 'socket.io',
    host: window.location.hostname + ':6001'
});

// Laravel 官方推荐使用 pusher
// window.Pusher = require('pusher-js');

// window.Echo = new Echo({
//     broadcaster: 'pusher',
//     key: process.env.MIX_PUSHER_APP_KEY,
//     cluster: process.env.MIX_PUSHER_APP_CLUSTER,
//     encrypted: true
// });
로그인 후 복사

接下来我们就可以使用 Echo 实例,监听后端发过来的广播或者通知了。

首先我们利用已经给的 ExampleComponent 改造下,创建 Echo 监听,等待数据的到来,然后再显示在页面上。代码简单:

<template>
    <p>
        </p>
<p>
            </p>
<p>
                </p>
<p>
                    </p>
<p>Example Component</p>

                    <p>
                        </p>
<ul>
                            <li>{{ name }}</li>
                        </ul>
                    
                
            
        
    
</template>

<script>
    export default {
        data () {
            return {
                names: []
            }
        },
        mounted() {
            let that = this
            // 12. 创建 Echo 监听
            Echo.channel(&#39;rss&#39;)
                .listen(&#39;RssCreatedEvent&#39;, (e) => {
                    that.names.push(e.name)
                });
        }
    }
</script>
로그인 후 복사

我们在后端添加一个 rss 被创建的事件 RssCreatedEvent,并继承 ShouldBroadcast

// 13. 创建 RssCreatedEvent 事件
php artisan make:event RssCreatedEvent
로그인 후 복사

我们使用假数据,让它返回当前的时间,方便查看效果:

<?php namespace App\Events;

use Carbon\Carbon;
use Illuminate\Broadcasting\Channel;
use Illuminate\Queue\SerializesModels;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;

class RssCreatedEvent implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    public function broadcastOn()
    {
        // 14. 创建频道
        return new Channel(&#39;rss&#39;);
    }

    /**
     * 指定广播数据。
     *
     * @return array
     */
    public function broadcastWith()
    {
        // 返回当前时间
        return [&#39;name&#39; => Carbon::now()->toDateTimeString()];
    }
}
로그인 후 복사

然后我们就可以做一个定时任务了,让它每隔一分钟,广播一次:

protected function schedule(Schedule $schedule)
{
    // 15. 每隔一分钟执行一次
    $schedule->call(function () {
        event(new RssCreatedEvent());
    })->everyMinute();
}
로그인 후 복사

最后让首页加载 vue 组件,刷新测试:

nbsp;html>
getLocale() }}">
    
        <meta>
        <meta>
        <meta>
        <meta>
        <title>Laravel</title>
    
    
    <p>
        <example-component></example-component>
    </p>
    <script></script>
    
로그인 후 복사

注:需要在 header 引入

<meta>
로그인 후 복사

编译前端:

// 16. 运行 watch
yarn run watch-poll
로그인 후 복사

刷新网页,查看运行效果:

Laravel 프레임워크에서 Echo를 사용하는 과정

如我们所愿,每隔一分钟,广播一次,前端 laravel-echo 监听并捕获该广播,然后读取数据,展示出来。

总结

到目前为止,我们用到的技术都有:

1.laradock 的使用

2.laravel echo server 的使用

3.广播事件

4.event() 辅助函数

5.$schedule 定时任务

6.Laravel Echo 的使用

我们基本可以使用 Laravel Echo 了,至于更深入的使用,推荐查看官网文档。

最后再一次强烈推荐大家用 laradock 来部署 Docker 开发环境,因为你想要用到的工具和环境,相信 laradock중국에서는 푸셔 사용을 개인적으로 권장하지 않습니다. 접속속도에 영향을 미치게 되고, 아직은 상용제품이기 때문입니다.

오늘 가장 간단한 "16" 단계를 활용하여 laradocklaravel-echo-server의 코드 통합을 통해 라라벨 에코.

기본 환경 구축

rrreeeLaravel 프레임워크에서 Echo를 사용하는 과정# 🎜 🎜#rrreee

좋아요, 브라우저에 입력을 시작하겠습니다: http://localhost, 웹사이트가 실행 중입니다


Laravel 프레임워크에서 Echo를 사용하는 과정#🎜🎜 #

Laravel Echo 서버 사용하기

laradock은 "Laravel Echo 서버"를 통합하고 있기 때문에 사용하기 매우 편리합니다. Laravel Echo입니다.

rrreee백엔드 구성을 마치고 프런트엔드 플러그인 설치에 들어갔습니다. 결국 Laravel Echo는 프런트엔드 도구입니다. rrreee

resources/assets/js/bootstrap.js에서 Echo 인스턴스화:

rrreee다음으로 할 일은 다음과 같습니다. 백엔드에서 보낸 브로드캐스트나 알림을 들으려면 Echo 인스턴스를 사용하세요.

우선, 주어진 ExampleComponent를 사용하여 수정하고, Echo 리스너를 생성하고, 데이터 도착을 기다린 후 표시합니다. 페이지에 있어요. 코드는 간단합니다.

rrreee

백엔드에 rss 생성 이벤트 RssCreatedEvent를 추가하고 ShouldBroadcast를 상속합니다.

rrreee효과를 쉽게 볼 수 있도록 가짜 데이터를 사용하여 현재 시간으로 되돌립니다. rrreee

그러면 예약된 작업을 만들어 1분마다 만들 수 있습니다 , 한 번 브로드캐스트:
rrreee
마지막으로 홈 페이지에서 vue 구성 요소를 로드하고 테스트를 새로 고칩니다. #🎜🎜#rrreee#🎜🎜#참고: header #🎜🎜#rrreee#🎜🎜#을 도입하여 프런트 엔드를 컴파일합니다: #🎜🎜#rrreee#🎜🎜# 웹 페이지를 새로 고치고 실행 효과를 확인합니다: #🎜🎜##🎜🎜#  Laravel 프레임워크에서 Echo를 사용하는 과정 #🎜🎜##🎜🎜#우리가 바라는 대로 브로드캐스트는 1분마다 수행됩니다. 프런트엔드 laravel-echo는 방송한 다음 데이터를 읽고 표시합니다. #🎜🎜#

요약

#🎜🎜#지금까지 우리가 사용한 기술은 다음과 같습니다: #🎜🎜## 🎜🎜 #1.laradock 활용법#🎜🎜##🎜🎜#2.laravel echo server 활용법#🎜🎜##🎜🎜#3.방송 이벤트#🎜🎜##🎜🎜#4.event() 보조 기능 #🎜 🎜##🎜🎜#5.$예약된 작업#🎜🎜##🎜🎜#6.Using Laravel Echo#🎜🎜##🎜🎜#기본적으로 Laravel Echo를 사용할 수 있습니다. 심층적인 사용을 위해서는 공식 웹사이트 문서를 확인하는 것이 좋습니다. #🎜🎜##🎜🎜#마지막으로, Docker 개발 환경을 배포하려면 laradock을 사용하는 것이 좋습니다. laradock에는 모든 도구와 환경이 있다고 믿기 때문입니다. 당신을 위해 준비되었습니다. #🎜🎜##🎜🎜#위 내용은 이 글의 전체 내용입니다. 더 많은 라라벨 내용을 보려면 #🎜🎜#laravel 프레임워크 진입 튜토리얼#🎜🎜#을 참고하세요. #🎜🎜##🎜🎜# 추천 관련 기사: #🎜🎜##🎜🎜##🎜🎜##🎜🎜#Laravel 프레임워크의 Autoloader 모듈 코드 분석 #🎜🎜##🎜🎜##🎜🎜# #🎜 🎜#Laravel 프레임워크의 모양 패턴에 대한 심층 분석#🎜🎜##🎜🎜##🎜🎜#관련 강좌 추천: #🎜🎜##🎜🎜##🎜🎜#최신 Laravel 동영상 튜토리얼 추천 5개 2017년에는#🎜 🎜##🎜🎜##🎜🎜##🎜🎜#

위 내용은 Laravel 프레임워크에서 Echo를 사용하는 과정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? PHP에서 HTML/XML을 어떻게 구문 분석하고 처리합니까? Feb 07, 2025 am 11:57 AM

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

문자열로 모음을 계산하는 PHP 프로그램 문자열로 모음을 계산하는 PHP 프로그램 Feb 07, 2025 pm 12:12 PM

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

이전에 몰랐던 후회되는 PHP 함수 7가지 이전에 몰랐던 후회되는 PHP 함수 7가지 Nov 13, 2024 am 09:42 AM

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.

Laravel에서는 이메일로 확인 코드를 보내지 못하는 상황을 처리하는 방법은 무엇입니까? Laravel에서는 이메일로 확인 코드를 보내지 못하는 상황을 처리하는 방법은 무엇입니까? Mar 31, 2025 pm 11:48 PM

Laravel의 이메일을 처리하지 않는 방법은 LaRavel을 사용하는 것입니다.

PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). Apr 03, 2025 am 12:04 AM

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? Apr 01, 2025 am 07:09 AM

DCAT를 사용할 때 DCATADMIN (LARAVEL-ADMIN)에서 데이터를 추가하려면 사용자 정의의 테이블 기능을 구현하는 방법 ...

See all articles