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

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

Client can not be authenticated, got HTTP status 419

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

本作品采用《CC 协议》,转载必须注明作者和本文链接
心之所向,素履以往。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 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

3年前 评论

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