Man*_*yen 4 php pusher vuejs2 laravel-echo laravel-5.4
祝你今天过得愉快 !
我有一个问题:我设置了 Laravel Echo & Pusher,但遇到了这个错误,不知道如何解决 :(
我检查了我的 app-key、app-cluster,但都是正确的。
有人能帮我吗?
应用程序.js
const app = new Vue({
el: '#app',
data: {
messages: []
},
methods:{
addMessage(message){
this.messages.push(message);
axios.post('/messages', message).then(response => {
console.log(response);
});
}
},
created(){
axios.get('/messages').then(response => {
this.messages = response.data;
});
Echo.channel('chatroom')
.listen('MessageEvent', (e) => {
console.log(e);
});
}
})
Run Code Online (Sandbox Code Playgroud)
引导程序.js
import Echo from 'laravel-echo'
window.Pusher = require('pusher-js');
window.Echo = new Echo({
broadcaster: 'pusher',
key: '************',
cluster: 'ap1',
encrypted: false
});
Run Code Online (Sandbox Code Playgroud)
消息事件
use Dispatchable, InteractsWithSockets, SerializesModels;
public $message, $user;
public function __construct(Message $message, User $user)
{
$this->message = $message;
//query
$this->user = $user;
}
public function broadcastOn()
{
return new PresenceChannel('chatroom');
}
Run Code Online (Sandbox Code Playgroud)
频道.php
Broadcast::channel('App.User.{id}', function ($user, $id) {
return (int) $user->id === (int) $id;
});
Broadcast::channel('chatroom', function ($user, $id) {
return $user;
});
Run Code Online (Sandbox Code Playgroud)
错误403或500 /广播/与Laravel版本> 5.3&推权威性,你需要改变你的代码资源/资产/ JS / bootstrap.js与
window.Echo = new Echo({
broadcaster: 'pusher',
key: 'your key',
cluster: 'your cluster',
encrypted: true,
auth: {
headers: {
Authorization: 'Bearer ' + YourTokenLogin
},
},
});
Run Code Online (Sandbox Code Playgroud)
在app/Providers/BroadcastServiceProvider.php 中更改为
Broadcast::routes()
Run Code Online (Sandbox Code Playgroud)
和
Broadcast::routes(['middleware' => ['auth:api']]);
Run Code Online (Sandbox Code Playgroud)
或者
Broadcast::routes(['middleware' => ['jwt.auth']]); //if you use JWT
Run Code Online (Sandbox Code Playgroud)
它对我有用,希望对你有帮助。