php - Laravel-echo-server 没有连接客户端到服务器
问题描述
laravel-echo-server.json
{
"authHost": "http://want_can.lc",
"authEndpoint": "/broadcasting/auth",
"clients": [],
"database": "redis",
"databaseConfig": {
"redis": {
"port": 6379,
"host":"127.0.0.1",
"keyPrefix":null
},
"sqlite": {
"databasePath": "/database/laravel-echo-server.sqlite"
}
},
"devMode": true,
"host": null,
"port": "6001",
"protocol": "http",
"socketio": {},
"secureOptions": 67108864,
"sslCertPath": "",
"sslKeyPath": "",
"sslCertChainPath": "",
"sslPassphrase": "",
"subscribers": {
"http": true,
"redis": true
},
"apiOriginAllow": {
"allowCors": false,
"allowOrigin": "",
"allowMethods": "",
"allowHeaders": ""
}
}
引导程序.js
if (typeof io !== 'undefined') {
window.Echo = new Echo({
broadcaster: 'socket.io',
host:window.location.hostname +":"+ '6001',
});
}else{
console.log('AAA!')
}
私聊活动
class PrivateChat implements ShouldBroadcast
{
use Dispatchable, InteractsWithSockets, SerializesModels;
public $data;
public $user;
public function __construct($data,User $user)
{
$this->data=$data;
$this->user=$user;
$this->dontBroadcastToCurrentUser();
}
public function broadcastOn()
{
Message::create($this->data,$this->user);
return new PrivateChannel('room.'.$this->data['room_id']);
}
}
控制器
class MessageController
{
public $service;
public function __construct(ChatroomService $service)
{
$this->service=$service;
}
public function message(ChatRequest $request,User $user)
{
event ( new PrivateChat($request->all(), $user));
}
}
频道.php
Broadcast::channel('room.{room_id}', function ( $user, $room_id) {
return $user->chatroomsCustomer->contains($room_id)||$user->chatroomsExecutor->contains($room_id);
});
redis 的 config/database.php 密钥前缀设置
'options' => [
'cluster' => env('REDIS_CLUSTER', 'redis'),
'prefix' => null,
],
vue.js 组件
methods:{
update:function (id) {
axios.post('chatroom',{
room_id:id
}).then((response)=>{
this.message=response.data;
});
window.Echo
.private('room'+{id})
.listen('PrivateChat',
({data})=>{
console.log(data)
this.message.messages.push(data.body)
})
},
sendMessage(room_id){
axios.post('/message/'+this.user,{
text:this.textMessage,
room_id:room_id
}).then((response)=>{});
this.message.messages.push({user_id:this.user,'text':this.textMessage})
this.textMessage='';
}
}
}
启动 laravel-echo-server。选项卡网络https://prnt.sc/xyunid套接字不生成 sid。如果用户在终端输入消息
Channel: private-room.1
Event: App\Events\PrivateChat
这是我在队列中得到的
[2021-02-01 06:50:25][RXvfnlILeDt6J2MTWAXPA9EStl1Cgi5X] Processing: App\Events\PrivateChat
[2021-02-01 06:50:25][RXvfnlILeDt6J2MTWAXPA9EStl1Cgi5X] Processed: App\Events\PrivateChat
解决方案
问题出在 sockets.io-clent 版本中。它们已经是第三个版本,并且 laravel-echo-server 还没有重做。
推荐阅读
- excel - 如何在熊猫中显示excelsheet记录?
- c++ - make: 找不到 -lthrift
- python - Python比较两个数据框的列并生成匹配行的索引
- visual-studio-code - Visual Studio Code 未在 mac catalina 中打开
- ruby-on-rails - 具有多种角色的多种类型用户的数据库架构
- c - 写入字符串数组时出现分段错误
- java - 为什么在命令提示符下运行时显示“错误:无法找到或加载简单的主类”
- javascript - 为 highcharts 中的列组图设置背景颜色
- html - 如何在 HTML 或 React 中显示来自 node.js 的信息,最好不使用 express?
- php - 如何在 WordPress 自定义帖子类型中按类别显示帖子