【问题标题】:Angular 2, Laravel 5.2 and ioredis real time appAngular 2、Laravel 5.2 和 ioredis 实时应用
【发布时间】:2017-05-24 23:18:34
【问题描述】:

我已经搜索了将近 10 个小时,才找到 similar question,尽管我已尽最大努力使之成为可能,但他们没有得到答案。对不起,如果这只是一个愚蠢的问题,但要么我不知道,要么它没有按应有的方式工作。

所以我的 angular 2 组件有类似

import * as io from "socket.io-client";
export class TasklistComponent implements OnInit {
 ngOnInit() {
    var socket = io("http://localhost:3000");
    socket.on("test-channel:TasklistModified", function(message) {
        console.log(message);
    });
 }
}

我已经在我的 laravel 根目录上配置了socket.js

var app = require('express');
var http = require('http').Server(app);
var io = require("socket.io")(http);
var Redis = require("ioredis");
var redis = new Redis({
   scheme: 'localhost',
   port: 6379,          // Redis port
   host: '127.0.0.1'
});

redis.subscribe('test-channel', function(err, count) {
   //..
});

redis.on('message', function(channel, message) {
   console.log("Message Recieved", channel, message);

   message = JSON.Parse(message);
   io.emit(channel + ":" + message.event, message.payload);
});

http.listen(3000, function() {
   console.log('listening on port 3000');
});

我在 laravel routes.php 上有以下事件类和路由

Route::get('event', function() {
   event(new TasklistModified([
        'name' => 'test'
    ]));
});
//Event Class
use App\Events\Event;
use Illuminate\Queue\SerializesModels;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;

class TasklistModified extends Event implements ShouldBroadcast
{
    use SerializesModels;
    public $tasklist;
    public function __construct($tasklist)
    {
        $this->tasklist = $tasklist;
    }
    public function broadcastOn()
    {
        return ['test-channel'];
    }
}

我打开了两个浏览器并尝试运行,

角度:本地主机:4200

还有 Laravel

本地主机:8000/事件

我在 laravel 中点击event 路由时没有得到任何响应。

正在运行的应用程序

节点:3000

Laravel:8000

Angular2:4200

您的回答将不胜感激。 谢谢

【问题讨论】:

    标签: node.js laravel angular redis


    【解决方案1】:

    我忘记在我的 Windows 机器上安装 Redis。现在一切似乎都很好。 :) Here's how you can install Redis on Windows。试试@Dherik 答案

    【讨论】:

      猜你喜欢
      • 2018-05-25
      • 1970-01-01
      • 2016-08-20
      • 1970-01-01
      • 2016-11-12
      • 1970-01-01
      • 1970-01-01
      • 2016-09-27
      • 2014-09-10
      相关资源
      最近更新 更多