【发布时间】: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