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

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

Client can not be authenticated, got HTTP status 419

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

本作品采用《CC 协议》,转载必须注明作者和本文链接
心之所向,素履以往。
《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
讨论数量: 21

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

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

我的是前后端分离

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

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

2年前 评论

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