laravel-echo,加入私人频道报错419,解决。

使用laravel-echo,加入私人频道,报如下错误:

Client can not be authenticated, got HTTP status 419

解决方案:在对应页面加入<meta name="csrf-token" content="{{ csrf_token() }}">

本作品采用《CC 协议》,转载必须注明作者和本文链接
心之所向,素履以往。
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 21

还可以在初始化Echo时加 auth 参数:

window.EchoPrivate = new Echo({
   ...
    auth: {
        headers: {
            // 默认自定义授权验证接口需要 csrf_token 验证
            'X-CSRF-Token': "{{ csrf_token() }}",
        }
    },
    ...
});
3年前 评论
lmdfx (楼主) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前
LiamHao (作者) 3年前
lmdfx (楼主) 3年前

我的是前后端分离

window.Echo = new Echo({
  broadcaster: "socket.io",
  host: window.location.hostname + ":6001",
  auth: {
    headers: {
      Authorization: localStorage.token,
    },
  },
});
3年前 评论

大佬,关于上次laravel-echo的问题,解决之后,可以正常使用了,端口监听的是6001,但是经过网站经过安全扫描之后,警告说6001使用了TLSV1.0和TLSV1.1,像正常的443端口,我是在nginx的配置文件里面限制ssl_protocols 和ssl_ciphers ,但是这个6001监听的端口好像没有走nginx,我应该如果处理呢,您这边有遇到过吗@LiamHao

2年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!